summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--linguistic/source/gciterator.cxx30
1 files changed, 12 insertions, 18 deletions
diff --git a/linguistic/source/gciterator.cxx b/linguistic/source/gciterator.cxx
index f324e514e0fa..b2f41628fd64 100644
--- a/linguistic/source/gciterator.cxx
+++ b/linguistic/source/gciterator.cxx
@@ -749,33 +749,27 @@ sal_Int32 GrammarCheckingIterator::GetSuggestedEndOfSentence(
{
// internal method; will always be called with locked mutex
- // FIXME! this is a bug, the xBreakIterator var is hiding an issue!
- // But if I fix it, the sw/complex tests start failing.
- uno::Reference< i18n::XBreakIterator > xBreakIterator;
if (!m_xBreakIterator.is())
{
uno::Reference< uno::XComponentContext > xContext = ::comphelper::getProcessComponentContext();
- xBreakIterator = i18n::BreakIterator::create(xContext);
+ m_xBreakIterator = i18n::BreakIterator::create(xContext);
}
sal_Int32 nTextLen = rText.getLength();
- sal_Int32 nEndPosition = nTextLen;
- if (m_xBreakIterator.is())
+ sal_Int32 nEndPosition;
+ sal_Int32 nTmpStartPos = nSentenceStartPos;
+ do
{
- sal_Int32 nTmpStartPos = nSentenceStartPos;
- do
- {
+ nEndPosition = nTextLen;
+ if (nTmpStartPos < nTextLen)
+ nEndPosition = m_xBreakIterator->endOfSentence( rText, nTmpStartPos, rLocale );
+ if (nEndPosition < 0)
nEndPosition = nTextLen;
- if (nTmpStartPos < nTextLen)
- nEndPosition = m_xBreakIterator->endOfSentence( rText, nTmpStartPos, rLocale );
- if (nEndPosition < 0)
- nEndPosition = nTextLen;
- ++nTmpStartPos;
- }
- while (nEndPosition <= nSentenceStartPos && nEndPosition < nTextLen);
- if (nEndPosition > nTextLen)
- nEndPosition = nTextLen;
+ ++nTmpStartPos;
}
+ while (nEndPosition <= nSentenceStartPos && nEndPosition < nTextLen);
+ if (nEndPosition > nTextLen)
+ nEndPosition = nTextLen;
return nEndPosition;
}