summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sw/source/core/unocore/unotext.cxx35
1 files changed, 11 insertions, 24 deletions
diff --git a/sw/source/core/unocore/unotext.cxx b/sw/source/core/unocore/unotext.cxx
index 3298d00c7eea..646a802b61de 100644
--- a/sw/source/core/unocore/unotext.cxx
+++ b/sw/source/core/unocore/unotext.cxx
@@ -114,8 +114,7 @@ public:
void ConvertCell(
const uno::Sequence< uno::Reference< text::XTextRange > > & rCell,
std::vector<SwNodeRange> & rRowNodes,
- SwNodeRange *const pLastCell,
- bool & rbExcept);
+ SwNodeRange *const pLastCell);
};
@@ -1781,8 +1780,7 @@ static bool lcl_SimilarPosition( const sal_Int32 nPos1, const sal_Int32 nPos2 )
void SwXText::Impl::ConvertCell(
const uno::Sequence< uno::Reference< text::XTextRange > > & rCell,
std::vector<SwNodeRange> & rRowNodes,
- SwNodeRange *const pLastCell,
- bool & rbExcept)
+ SwNodeRange *const pLastCell)
{
if (rCell.getLength() != 2)
{
@@ -1848,15 +1846,13 @@ void SwXText::Impl::ConvertCell(
}
if (nOpenNodeBlock < 0)
{
- rbExcept = true;
- break;
+ throw lang::IllegalArgumentException();
}
++aCellIndex;
}
if (nOpenNodeBlock != 0)
{
- rbExcept = true;
- return;
+ throw lang::IllegalArgumentException();
}
}
@@ -1885,7 +1881,7 @@ void SwXText::Impl::ConvertCell(
// same node as predecessor then equal nContent?
if (0 != aStartCellPam.Start()->nContent.GetIndex())
{
- rbExcept = true;
+ throw lang::IllegalArgumentException();
}
else
{
@@ -1916,7 +1912,7 @@ void SwXText::Impl::ConvertCell(
}
else
{
- rbExcept = true;
+ throw lang::IllegalArgumentException();
}
}
// now check if there's a need to insert another paragraph break
@@ -2113,9 +2109,7 @@ SwXText::convertToTable(
const uno::Sequence< uno::Sequence< uno::Reference< text::XTextRange > > >*
pTableRanges = rTableRanges.getConstArray();
std::vector< std::vector<SwNodeRange> > aTableNodes;
- bool bExcept = false;
- for (sal_Int32 nRow = 0; !bExcept && (nRow < rTableRanges.getLength());
- ++nRow)
+ for (sal_Int32 nRow = 0; nRow < rTableRanges.getLength(); ++nRow)
{
std::vector<SwNodeRange> aRowNodes;
const uno::Sequence< uno::Reference< text::XTextRange > >* pRow =
@@ -2124,11 +2118,10 @@ SwXText::convertToTable(
if (0 == nCells) // this would lead to no pLastCell below
{ // and make it impossible to detect node gaps
- bExcept = true;
- break;
+ throw lang::IllegalArgumentException();
}
- for (sal_Int32 nCell = 0; !bExcept && nCell < nCells; ++nCell)
+ for (sal_Int32 nCell = 0; nCell < nCells; ++nCell)
{
SwNodeRange *const pLastCell(
(nCell == 0)
@@ -2136,18 +2129,12 @@ SwXText::convertToTable(
? nullptr
: &*aTableNodes.rbegin()->rbegin())
: &*aRowNodes.rbegin());
- m_pImpl->ConvertCell(pRow[nCell], aRowNodes, pLastCell, bExcept);
+ m_pImpl->ConvertCell(pRow[nCell], aRowNodes, pLastCell);
}
- assert(bExcept || !aRowNodes.empty());
+ assert(!aRowNodes.empty());
aTableNodes.push_back(aRowNodes);
}
- if(bExcept)
- {
- m_pImpl->m_pDoc->GetIDocumentUndoRedo().Undo();
- throw lang::IllegalArgumentException();
- }
-
std::vector< TableColumnSeparators >
aRowSeparators(rRowProperties.getLength());
std::vector<VerticallyMergedCell> aMergedCells;