summaryrefslogtreecommitdiff
path: root/i18npool/source/breakiterator
diff options
context:
space:
mode:
authorKhaled Hosny <khaledhosny@eglug.org>2018-05-21 15:41:52 +0200
committerEike Rathke <erack@redhat.com>2018-05-22 19:25:01 +0200
commit98908d79a4b145f3c04d98812b2207bf433fcf1b (patch)
tree40bdac737cd54e6a32e3bd4caeb285d09e5734b7 /i18npool/source/breakiterator
parent6924586821805b7a338c8e746141f51e3ba29560 (diff)
Fold BreakIterator_CTL into BreakIterator_th
The split is pointless and misleading, there are no other subclasses of BreakIterator_CTL. Change-Id: I66e66834e6e064cea29f543434a35682ee7cd35d Reviewed-on: https://gerrit.libreoffice.org/54638 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Eike Rathke <erack@redhat.com>
Diffstat (limited to 'i18npool/source/breakiterator')
-rw-r--r--i18npool/source/breakiterator/breakiterator_ctl.cxx132
-rw-r--r--i18npool/source/breakiterator/breakiterator_th.cxx93
2 files changed, 89 insertions, 136 deletions
diff --git a/i18npool/source/breakiterator/breakiterator_ctl.cxx b/i18npool/source/breakiterator/breakiterator_ctl.cxx
deleted file mode 100644
index 932fb1b77182..000000000000
--- a/i18npool/source/breakiterator/breakiterator_ctl.cxx
+++ /dev/null
@@ -1,132 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- *
- * This file incorporates work covered by the following license notice:
- *
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed
- * with this work for additional information regarding copyright
- * ownership. The ASF licenses this file to you under the Apache
- * License, Version 2.0 (the "License"); you may not use this file
- * except in compliance with the License. You may obtain a copy of
- * the License at http://www.apache.org/licenses/LICENSE-2.0 .
- */
-
-
-#include <com/sun/star/i18n/CharacterIteratorMode.hpp>
-#include <breakiterator_ctl.hxx>
-
-using namespace ::com::sun::star;
-using namespace ::com::sun::star::uno;
-using namespace ::com::sun::star::i18n;
-using namespace ::com::sun::star::lang;
-
-namespace i18npool {
-
-/**
- * Constructor.
- */
-BreakIterator_CTL::BreakIterator_CTL() :
- cachedText(),
- nextCellIndex( nullptr ),
- previousCellIndex( nullptr ),
- cellIndexSize( 512 )
-{
- cBreakIterator = "com.sun.star.i18n.BreakIterator_CTL";
- // to improve performance, alloc big enough memory in construct.
- nextCellIndex = static_cast<sal_Int32*>(calloc(cellIndexSize, sizeof(sal_Int32)));
- previousCellIndex = static_cast<sal_Int32*>(calloc(cellIndexSize, sizeof(sal_Int32)));
-}
-
-/**
- * Deconstructor.
- */
-BreakIterator_CTL::~BreakIterator_CTL()
-{
- free(nextCellIndex);
- free(previousCellIndex);
-}
-
-sal_Int32 SAL_CALL BreakIterator_CTL::previousCharacters( const OUString& Text,
- sal_Int32 nStartPos, const lang::Locale& rLocale,
- sal_Int16 nCharacterIteratorMode, sal_Int32 nCount, sal_Int32& nDone )
-{
- if (nCharacterIteratorMode == CharacterIteratorMode::SKIPCELL ) {
- nDone = 0;
- if (nStartPos > 0) { // for others to skip cell.
- makeIndex(Text, nStartPos);
-
- if (nextCellIndex[nStartPos-1] == 0) // not a CTL character
- return BreakIterator_Unicode::previousCharacters(Text, nStartPos, rLocale,
- nCharacterIteratorMode, nCount, nDone);
- else while (nCount > 0 && nextCellIndex[nStartPos - 1] > 0) {
- nCount--; nDone++;
- nStartPos = previousCellIndex[nStartPos - 1];
- }
- } else
- nStartPos = 0;
- } else { // for BS to delete one char.
- for (nDone = 0; nDone < nCount && nStartPos > 0; nDone++)
- Text.iterateCodePoints(&nStartPos, -1);
- }
-
- return nStartPos;
-}
-
-sal_Int32 SAL_CALL BreakIterator_CTL::nextCharacters(const OUString& Text,
- sal_Int32 nStartPos, const lang::Locale& rLocale,
- sal_Int16 nCharacterIteratorMode, sal_Int32 nCount, sal_Int32& nDone)
-{
- sal_Int32 len = Text.getLength();
- if (nCharacterIteratorMode == CharacterIteratorMode::SKIPCELL ) {
- nDone = 0;
- if (nStartPos < len) {
- makeIndex(Text, nStartPos);
-
- if (nextCellIndex[nStartPos] == 0) // not a CTL character
- return BreakIterator_Unicode::nextCharacters(Text, nStartPos, rLocale,
- nCharacterIteratorMode, nCount, nDone);
- else while (nCount > 0 && nextCellIndex[nStartPos] > 0) {
- nCount--; nDone++;
- nStartPos = nextCellIndex[nStartPos];
- }
- } else
- nStartPos = len;
- } else {
- for (nDone = 0; nDone < nCount && nStartPos < Text.getLength(); nDone++)
- Text.iterateCodePoints(&nStartPos);
- }
-
- return nStartPos;
-}
-
-// This method should be overwritten by derived language specific class.
-void BreakIterator_CTL::makeIndex(const OUString& /*text*/, sal_Int32 /*pos*/)
-{
- throw RuntimeException();
-}
-
-// Make sure line is broken on cell boundary if we implement cell iterator.
-LineBreakResults SAL_CALL BreakIterator_CTL::getLineBreak(
- const OUString& Text, sal_Int32 nStartPos,
- const lang::Locale& rLocale, sal_Int32 nMinBreakPos,
- const LineBreakHyphenationOptions& hOptions,
- const LineBreakUserOptions& bOptions )
-{
- LineBreakResults lbr = BreakIterator_Unicode::getLineBreak(Text, nStartPos,
- rLocale, nMinBreakPos, hOptions, bOptions );
- if (lbr.breakIndex < Text.getLength()) {
- makeIndex(Text, lbr.breakIndex);
- lbr.breakIndex = previousCellIndex[ lbr.breakIndex ];
- }
- return lbr;
-}
-
-}
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/i18npool/source/breakiterator/breakiterator_th.cxx b/i18npool/source/breakiterator/breakiterator_th.cxx
index 49f81047247c..aa9d4e8b6ea5 100644
--- a/i18npool/source/breakiterator/breakiterator_th.cxx
+++ b/i18npool/source/breakiterator/breakiterator_th.cxx
@@ -17,28 +17,113 @@
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
+
+#include <com/sun/star/i18n/CharacterIteratorMode.hpp>
#include <breakiterator_th.hxx>
#include <wtt.h>
#include <string.h>
#include <algorithm>
+using namespace ::com::sun::star;
using namespace ::com::sun::star::uno;
+using namespace ::com::sun::star::i18n;
using namespace ::com::sun::star::lang;
namespace i18npool {
-
-// class Breakiterator_th
-// ----------------------------------------------------;
-BreakIterator_th::BreakIterator_th()
+/**
+ * Constructor.
+ */
+BreakIterator_th::BreakIterator_th() :
+ cachedText(),
+ nextCellIndex( nullptr ),
+ previousCellIndex( nullptr ),
+ cellIndexSize( 512 )
{
cBreakIterator = "com.sun.star.i18n.BreakIterator_th";
+ // to improve performance, alloc big enough memory in construct.
+ nextCellIndex = static_cast<sal_Int32*>(calloc(cellIndexSize, sizeof(sal_Int32)));
+ previousCellIndex = static_cast<sal_Int32*>(calloc(cellIndexSize, sizeof(sal_Int32)));
lineRule=nullptr;
}
+/**
+ * Deconstructor.
+ */
BreakIterator_th::~BreakIterator_th()
{
+ free(nextCellIndex);
+ free(previousCellIndex);
+}
+
+sal_Int32 SAL_CALL BreakIterator_th::previousCharacters( const OUString& Text,
+ sal_Int32 nStartPos, const lang::Locale& rLocale,
+ sal_Int16 nCharacterIteratorMode, sal_Int32 nCount, sal_Int32& nDone )
+{
+ if (nCharacterIteratorMode == CharacterIteratorMode::SKIPCELL ) {
+ nDone = 0;
+ if (nStartPos > 0) { // for others to skip cell.
+ makeIndex(Text, nStartPos);
+
+ if (nextCellIndex[nStartPos-1] == 0) // not a CTL character
+ return BreakIterator_Unicode::previousCharacters(Text, nStartPos, rLocale,
+ nCharacterIteratorMode, nCount, nDone);
+ else while (nCount > 0 && nextCellIndex[nStartPos - 1] > 0) {
+ nCount--; nDone++;
+ nStartPos = previousCellIndex[nStartPos - 1];
+ }
+ } else
+ nStartPos = 0;
+ } else { // for BS to delete one char.
+ for (nDone = 0; nDone < nCount && nStartPos > 0; nDone++)
+ Text.iterateCodePoints(&nStartPos, -1);
+ }
+
+ return nStartPos;
+}
+
+sal_Int32 SAL_CALL BreakIterator_th::nextCharacters(const OUString& Text,
+ sal_Int32 nStartPos, const lang::Locale& rLocale,
+ sal_Int16 nCharacterIteratorMode, sal_Int32 nCount, sal_Int32& nDone)
+{
+ sal_Int32 len = Text.getLength();
+ if (nCharacterIteratorMode == CharacterIteratorMode::SKIPCELL ) {
+ nDone = 0;
+ if (nStartPos < len) {
+ makeIndex(Text, nStartPos);
+
+ if (nextCellIndex[nStartPos] == 0) // not a CTL character
+ return BreakIterator_Unicode::nextCharacters(Text, nStartPos, rLocale,
+ nCharacterIteratorMode, nCount, nDone);
+ else while (nCount > 0 && nextCellIndex[nStartPos] > 0) {
+ nCount--; nDone++;
+ nStartPos = nextCellIndex[nStartPos];
+ }
+ } else
+ nStartPos = len;
+ } else {
+ for (nDone = 0; nDone < nCount && nStartPos < Text.getLength(); nDone++)
+ Text.iterateCodePoints(&nStartPos);
+ }
+
+ return nStartPos;
+}
+
+// Make sure line is broken on cell boundary if we implement cell iterator.
+LineBreakResults SAL_CALL BreakIterator_th::getLineBreak(
+ const OUString& Text, sal_Int32 nStartPos,
+ const lang::Locale& rLocale, sal_Int32 nMinBreakPos,
+ const LineBreakHyphenationOptions& hOptions,
+ const LineBreakUserOptions& bOptions )
+{
+ LineBreakResults lbr = BreakIterator_Unicode::getLineBreak(Text, nStartPos,
+ rLocale, nMinBreakPos, hOptions, bOptions );
+ if (lbr.breakIndex < Text.getLength()) {
+ makeIndex(Text, lbr.breakIndex);
+ lbr.breakIndex = previousCellIndex[ lbr.breakIndex ];
+ }
+ return lbr;
}
#define SARA_AM 0x0E33