diff options
author | Laurent Godard <lgodard.libre@laposte.net> | 2013-08-08 17:18:29 +0200 |
---|---|---|
committer | Kohei Yoshida <kohei.yoshida@suse.de> | 2013-08-08 17:35:36 +0000 |
commit | f807403faa3a20a6b4e95c9e8441cd637e3e548d (patch) | |
tree | 7333fabadd8cd098f1347e9162fb6192764b87ad /sc/source/core/tool/editutil.cxx | |
parent | af53d7a181feaad2f75eeb0900030aa02868e338 (diff) |
import performance : do not use EditEngine anymore
Change-Id: I5849add3444cff15a201a276c8917fabc4b33262
Reviewed-on: https://gerrit.libreoffice.org/5317
Reviewed-by: Kohei Yoshida <kohei.yoshida@suse.de>
Tested-by: Kohei Yoshida <kohei.yoshida@suse.de>
Diffstat (limited to 'sc/source/core/tool/editutil.cxx')
-rw-r--r-- | sc/source/core/tool/editutil.cxx | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/sc/source/core/tool/editutil.cxx b/sc/source/core/tool/editutil.cxx index ea87597db03a..8935fad0a4c7 100644 --- a/sc/source/core/tool/editutil.cxx +++ b/sc/source/core/tool/editutil.cxx @@ -29,7 +29,7 @@ #include <editeng/flditem.hxx> #include <editeng/numitem.hxx> #include <editeng/justifyitem.hxx> -#include "editeng/editobj.hxx" +#include <editeng/editobj.hxx> #include <vcl/svapp.hxx> #include <vcl/outdev.hxx> #include <svl/inethist.hxx> @@ -81,16 +81,39 @@ static OUString lcl_GetDelimitedString( const EditEngine& rEngine, const sal_Cha return aRet.makeStringAndClear(); } +static OUString lcl_GetDelimitedString( const EditTextObject& rEdit, const sal_Char c ) +{ + sal_Int32 nParCount = rEdit.GetParagraphCount(); + OUStringBuffer aRet( nParCount * 80 ); + for (sal_Int32 nPar=0; nPar<nParCount; nPar++) + { + if (nPar > 0) + aRet.append(c); + aRet.append( rEdit.GetText( nPar )); + } + return aRet.makeStringAndClear(); +} + OUString ScEditUtil::GetSpaceDelimitedString( const EditEngine& rEngine ) { return lcl_GetDelimitedString(rEngine, ' '); } +OUString ScEditUtil::GetSpaceDelimitedString( const EditTextObject& rEdit ) +{ + return lcl_GetDelimitedString(rEdit, ' '); +} + OUString ScEditUtil::GetMultilineString( const EditEngine& rEngine ) { return lcl_GetDelimitedString(rEngine, '\n'); } +OUString ScEditUtil::GetMultilineString( const EditTextObject& rEdit ) +{ + return lcl_GetDelimitedString(rEdit, '\n'); +} + OUString ScEditUtil::GetString( const EditTextObject& rEditText, const ScDocument* pDoc ) { // ScFieldEditEngine is needed to resolve field contents. |