From f807403faa3a20a6b4e95c9e8441cd637e3e548d Mon Sep 17 00:00:00 2001 From: Laurent Godard Date: Thu, 8 Aug 2013 17:18:29 +0200 Subject: import performance : do not use EditEngine anymore Change-Id: I5849add3444cff15a201a276c8917fabc4b33262 Reviewed-on: https://gerrit.libreoffice.org/5317 Reviewed-by: Kohei Yoshida Tested-by: Kohei Yoshida --- sc/inc/editutil.hxx | 2 ++ sc/source/core/data/autonamecache.cxx | 6 +----- sc/source/core/tool/editutil.cxx | 25 ++++++++++++++++++++++++- 3 files changed, 27 insertions(+), 6 deletions(-) (limited to 'sc') diff --git a/sc/inc/editutil.hxx b/sc/inc/editutil.hxx index 88a42e8696da..34ffd34f514a 100644 --- a/sc/inc/editutil.hxx +++ b/sc/inc/editutil.hxx @@ -55,9 +55,11 @@ public: /// Retrieves string with paragraphs delimited by spaces static OUString GetSpaceDelimitedString( const EditEngine& rEngine ); + static OUString GetSpaceDelimitedString( const EditTextObject& rEdit ); /// Retrieves string with paragraphs delimited by new lines ('\n'). static OUString GetMultilineString( const EditEngine& rEngine ); + static OUString GetMultilineString( const EditTextObject& rEdit ); /** Retrieves string with paragraphs delimited by new lines ('\n'). diff --git a/sc/source/core/data/autonamecache.cxx b/sc/source/core/data/autonamecache.cxx index 5d2257b05836..02d74cd98ddf 100644 --- a/sc/source/core/data/autonamecache.cxx +++ b/sc/source/core/data/autonamecache.cxx @@ -72,11 +72,7 @@ const ScAutoNameAddresses& ScAutoNameCache::GetNameOccurrences( const String& rN { const EditTextObject* p = aIter.getEditText(); if (p) - { - ScFieldEditEngine& rEngine = pDoc->GetEditEngine(); - rEngine.SetText(*p); - aStr = ScEditUtil::GetMultilineString(rEngine); // string with line separators between paragraphs - } + aStr = ScEditUtil::GetMultilineString(*p); // string with line separators between paragraphs } break; case CELLTYPE_NONE: 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 #include #include -#include "editeng/editobj.hxx" +#include #include #include #include @@ -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 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. -- cgit v1.2.3