summaryrefslogtreecommitdiff
path: root/comphelper
diff options
context:
space:
mode:
authorNoel Grandin <noel.grandin@collabora.co.uk>2022-04-03 21:28:08 +0200
committerNoel Grandin <noel.grandin@collabora.co.uk>2022-04-04 13:48:11 +0200
commit5de24375515bc2932d299047e9cb8c9c9bf3ee1d (patch)
tree81c451b7ccbf90d6d3e219f26b62e98993fff7df /comphelper
parentc2e8a96a8107a37901e475c65a8e61211fc3b132 (diff)
use string_view in comphelper::string::split
Change-Id: I4afe8aee85905ee35ba195b00b454aefa0ba38af Reviewed-on: https://gerrit.libreoffice.org/c/core/+/132486 Tested-by: Jenkins Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
Diffstat (limited to 'comphelper')
-rw-r--r--comphelper/qa/string/test_string.cxx2
-rw-r--r--comphelper/source/misc/string.cxx55
2 files changed, 52 insertions, 5 deletions
diff --git a/comphelper/qa/string/test_string.cxx b/comphelper/qa/string/test_string.cxx
index 0619b873e0fb..5d3132756ad5 100644
--- a/comphelper/qa/string/test_string.cxx
+++ b/comphelper/qa/string/test_string.cxx
@@ -373,7 +373,7 @@ void TestString::testReverseString()
void TestString::testSplit()
{
- std::vector<OUString> aRet = ::comphelper::string::split("CTRL+ALT+F1", '+');
+ std::vector<OUString> aRet = ::comphelper::string::split(u"CTRL+ALT+F1", '+');
CPPUNIT_ASSERT_EQUAL(size_t(3), aRet.size());
CPPUNIT_ASSERT_EQUAL(OUString("CTRL"), aRet[0]);
CPPUNIT_ASSERT_EQUAL(OUString("ALT"), aRet[1]);
diff --git a/comphelper/source/misc/string.cxx b/comphelper/source/misc/string.cxx
index a3ee9bc58521..acdb6c88adcb 100644
--- a/comphelper/source/misc/string.cxx
+++ b/comphelper/source/misc/string.cxx
@@ -261,15 +261,62 @@ OUString convertCommaSeparated(
return buf.makeStringAndClear();
}
+/* copy of getToken from sal/, modified to take a string_view */
+static sal_Int32 getToken( OUString& ppThis,
+ std::u16string_view pStr,
+ sal_Int32 nToken,
+ sal_Unicode cTok,
+ sal_Int32 nIndex )
+{
+ assert(nIndex <= static_cast<sal_Int32>(pStr.size()));
+
+ // Set ppThis to an empty string and return -1 if either nToken or nIndex is
+ // negative:
+ if (nIndex >= 0 && nToken >= 0)
+ {
+ const auto* pOrgCharStr = pStr.data();
+ const auto* pCharStr = pOrgCharStr + nIndex;
+ sal_Int32 nLen = pStr.size() - nIndex;
+ sal_Int32 nTokCount = 0;
+ const auto* pCharStrStart = pCharStr;
+ while (nLen > 0)
+ {
+ if (*pCharStr == cTok)
+ {
+ nTokCount++;
+
+ if (nTokCount > nToken)
+ break;
+ if (nTokCount == nToken)
+ pCharStrStart = pCharStr + 1;
+ }
+
+ pCharStr++;
+ nLen--;
+ }
+ if (nTokCount >= nToken)
+ {
+ ppThis = OUString(pCharStrStart, pCharStr - pCharStrStart);
+ if (nLen > 0)
+ return pCharStr - pOrgCharStr + 1;
+ else
+ return -1;
+ }
+ }
+
+ ppThis.clear();
+ return -1;
+}
+
std::vector<OUString>
- split(const OUString& rStr, sal_Unicode cSeparator)
+ split(std::u16string_view rStr, sal_Unicode cSeparator)
{
std::vector< OUString > vec;
sal_Int32 idx = 0;
do
{
- OUString kw =
- rStr.getToken(0, cSeparator, idx);
+ OUString kw;
+ idx = getToken(kw, rStr, 0, cSeparator, idx);
kw = kw.trim();
if (!kw.isEmpty())
{
@@ -282,7 +329,7 @@ std::vector<OUString>
}
uno::Sequence< OUString >
- convertCommaSeparated( OUString const& i_rString )
+ convertCommaSeparated( std::u16string_view i_rString )
{
std::vector< OUString > vec = split(i_rString, ',');
return comphelper::containerToSequence(vec);