From 87934ed763b62d6e4b1245d6fe93befb6640f8ca Mon Sep 17 00:00:00 2001 From: Lionel Elie Mamane Date: Thu, 5 Feb 2015 21:32:12 +0100 Subject: destructors are not allowed to throw so move potentially throwing call to a manually called finish() additionally don't make it leak something that is not a RuntimeException, the caller does not expect it. Change-Id: I8b19585ae197f5ac8625dc85d4c4860a1c11b262 --- xmlscript/source/xmldlg_imexp/imp_share.hxx | 21 +++++++-- xmlscript/source/xmldlg_imexp/xmldlg_impmodels.cxx | 52 ++++++++++++++++++++++ 2 files changed, 69 insertions(+), 4 deletions(-) (limited to 'xmlscript') diff --git a/xmlscript/source/xmldlg_imexp/imp_share.hxx b/xmlscript/source/xmldlg_imexp/imp_share.hxx index 16ef33d24966..7fe35050811b 100644 --- a/xmlscript/source/xmldlg_imexp/imp_share.hxx +++ b/xmlscript/source/xmldlg_imexp/imp_share.hxx @@ -38,6 +38,8 @@ #include #include #include +#include +#include #include #include #include @@ -495,10 +497,21 @@ public: {} inline ~ControlImportContext() { - _pImport->_xDialogModel->insertByName( - _aId, css::uno::makeAny( - css::uno::Reference::query( - _xControlModel ) ) ); + } + + inline void finish() throw (css::xml::sax::SAXException, css::uno::RuntimeException, std::exception) + { + try + { + _pImport->_xDialogModel->insertByName( + _aId, css::uno::makeAny( + css::uno::Reference::query( + _xControlModel ) ) ); + } + catch(const css::container::ElementExistException &e) + { + throw css::lang::WrappedTargetRuntimeException("", e.Context, makeAny(e)); + } } }; diff --git a/xmlscript/source/xmldlg_imexp/xmldlg_impmodels.cxx b/xmlscript/source/xmldlg_imexp/xmldlg_impmodels.cxx index 6f2c6ea8393b..8c3beeda494c 100644 --- a/xmlscript/source/xmldlg_imexp/xmldlg_impmodels.cxx +++ b/xmlscript/source/xmldlg_imexp/xmldlg_impmodels.cxx @@ -101,6 +101,8 @@ void Frame::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } @@ -156,6 +158,8 @@ void MultiPage::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } Reference< xml::input::XElement > Page::startChildElement( @@ -208,6 +212,8 @@ void Page::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // progessmeter @@ -252,6 +258,8 @@ void ProgressBarElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // scrollbar @@ -302,6 +310,8 @@ void ScrollBarElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // spinbutton @@ -350,6 +360,8 @@ void SpinButtonElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // fixedline @@ -390,6 +402,8 @@ void FixedLineElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // patternfield @@ -438,6 +452,8 @@ void PatternFieldElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // formattedfield @@ -566,6 +582,8 @@ void FormattedFieldElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // timefield @@ -620,6 +638,8 @@ void TimeFieldElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // numericfield @@ -674,6 +694,8 @@ void NumericFieldElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // datefield @@ -729,6 +751,8 @@ void DateFieldElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // currencyfield @@ -785,6 +809,8 @@ void CurrencyFieldElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // filecontrol @@ -829,6 +855,8 @@ void FileControlElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // treecontrol @@ -875,6 +903,8 @@ void TreeControlElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // imagecontrol @@ -917,6 +947,8 @@ void ImageControlElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // textfield @@ -964,6 +996,8 @@ void TextElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // FixedHyperLink @@ -1013,6 +1047,8 @@ void FixedHyperLinkElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // edit @@ -1076,6 +1112,8 @@ void TextFieldElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // titledbox @@ -1148,6 +1186,8 @@ void TitledBoxElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // create radios AFTER group box! @@ -1194,6 +1234,8 @@ void TitledBoxElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) radioEvents.clear(); + + ctx.finish(); } // avoid ring-reference: // vector< radio elements > holding radio elements holding this (via _pParent) @@ -1290,6 +1332,8 @@ void RadioGroupElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) radioEvents.clear(); + + ctx.finish(); } // avoid ring-reference: // vector< radio elements > holding radio elements holding this (via _pParent) @@ -1415,6 +1459,8 @@ void MenuListElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // combobox @@ -1482,6 +1528,8 @@ void ComboBoxElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // checkbox @@ -1548,6 +1596,8 @@ void CheckBoxElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // button @@ -1612,6 +1662,8 @@ void ButtonElement::endElement() // avoid ring-reference: // vector< event elements > holding event elements holding this (via _pParent) _events.clear(); + + ctx.finish(); } // bulletinboard -- cgit