[Libreoffice-commits] core.git: Branch 'libreoffice-7-2' - basic/qa basic/source

Andreas Heinisch (via logerrit) logerrit at kemper.freedesktop.org
Tue Sep 7 11:47:07 UTC 2021


 basic/qa/vba_tests/collection.vb |   73 +++++++++++++++++++++++++++++++++++++++
 basic/source/classes/sb.cxx      |   11 ++++-
 2 files changed, 82 insertions(+), 2 deletions(-)

New commits:
commit 463a1012c3e22ce40209b9fddd7cd5df4ae0870a
Author:     Andreas Heinisch <andreas.heinisch at yahoo.de>
AuthorDate: Thu Sep 2 20:54:40 2021 +0200
Commit:     Mike Kaganski <mike.kaganski at collabora.com>
CommitDate: Tue Sep 7 13:46:33 2021 +0200

    tdf#144245 - Case-insensitive operation for non-ASCII characters
    
    Support case-insensitive operation for non-ASCII characters in the
    Collection object (VBA).
    
    Change-Id: Ie17560cb9aac5bfb32aa041744445dd4839681d6
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/121534
    Tested-by: Jenkins
    Reviewed-by: Eike Rathke <erack at redhat.com>
    Reviewed-by: Andreas Heinisch <andreas.heinisch at yahoo.de>
    (cherry picked from commit ef32c3b4f9b80918d6018e14297fa41245afd381)
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/121759
    Reviewed-by: Mike Kaganski <mike.kaganski at collabora.com>

diff --git a/basic/qa/vba_tests/collection.vb b/basic/qa/vba_tests/collection.vb
new file mode 100644
index 000000000000..0b765905290a
--- /dev/null
+++ b/basic/qa/vba_tests/collection.vb
@@ -0,0 +1,73 @@
+'
+' 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/.
+'
+
+Option VBASupport 1
+Option Explicit
+
+Function doUnitTest() As String
+    TestUtil.TestInit
+    verify_testCollection
+    doUnitTest = TestUtil.GetResult()
+End Function
+
+Sub verify_testCollection()
+
+    Dim a As Collection
+    Dim b As Collection
+
+    On Error Resume Next
+    Set a = New Collection
+    a.Add 1, "D"
+    a.Add 2, "d"
+    a.Add 3, "Д" ' uppercase Cyrillic script De
+    a.Add 4, "д" ' lowercase Cyrillic script De
+    On Error GoTo 0
+
+    On Error Resume Next
+    Set b = New Collection
+    b.Add 1, "SS"
+    b.Add 2, "ss"
+    b.Add 3, "ẞ" ' uppercase German Eszett
+    b.Add 4, "ß" ' lowercase German Eszett
+    On Error GoTo 0
+
+    On Error GoTo errorHandler
+
+    ' tdf#144245 - case-insensitive operation for non-ASCII characters
+    ' Without the fix in place, this test would have failed with
+    ' - Expected: 2
+    ' - Actual  : 3
+    TestUtil.AssertEqual(a.Count, 2, "a.Count")
+
+    ' tdf#144245 - case-insensitive operation for non-ASCII item access
+    ' Without the fix in place, this test would have failed with
+    ' - Expected: 1 for d, 3 for lowercase Cyrillic script De (д)
+    ' - Actual  : 2 for d, 4 for lowercase Cyrillic script De (д)
+    TestUtil.AssertEqual(a.Item("D"), 1, "a.Item(""D"")")
+    TestUtil.AssertEqual(a.Item("d"), 1, "a.Item(""d"")")
+    TestUtil.AssertEqual(a.Item("Д"), 3, "a.Item(""Д"")")
+    TestUtil.AssertEqual(a.Item("д"), 3, "a.Item(""д"")")
+
+    ' tdf#144245 - German Eszett is uppercased to a two-character 'SS'.
+    ' This test should fail after tdf#110003 has been fixed since the lowercase and the uppercase
+    ' German Eszett should be matched to the same index.
+    TestUtil.AssertEqual(b.Count, 3, "b.Count")
+    ' After the fix of tdf#110003
+    ' TestUtil.AssertEqual(b.Count, 2, "b.Count")
+
+    TestUtil.AssertEqual(a.Item("SS"), 1, "a.Item(""SS"")")
+    TestUtil.AssertEqual(a.Item("ss"), 1, "a.Item(""ss"")")
+    TestUtil.AssertEqual(a.Item("ẞ"), 3, "a.Item(""ẞ"")")
+    TestUtil.AssertEqual(a.Item("ß"), 4, "a.Item(""ß"")")
+    ' After the fix of tdf#110003
+    ' TestUtil.AssertEqual(a.Item("ß"), 3, "a.Item(""ß"")")
+
+    Exit Sub
+errorHandler:
+    TestUtil.ReportErrorHandler("verify_testCollection", Err, Error$, Erl)
+End Sub
diff --git a/basic/source/classes/sb.cxx b/basic/source/classes/sb.cxx
index 74eacdb504c6..75d5fea70640 100644
--- a/basic/source/classes/sb.cxx
+++ b/basic/source/classes/sb.cxx
@@ -47,6 +47,9 @@
 #include <memory>
 #include <unordered_map>
 
+#include <global.hxx>
+#include <unotools/transliterationwrapper.hxx>
+
 #include <com/sun/star/script/ModuleType.hpp>
 #include <com/sun/star/script/ModuleInfo.hpp>
 
@@ -2059,11 +2062,15 @@ sal_Int32 BasicCollection::implGetIndexForName(std::u16string_view rName)
     sal_Int32 nIndex = -1;
     sal_Int32 nCount = xItemArray->Count();
     sal_Int32 nNameHash = MakeHashCode( rName );
+
+    // tdf#144245 - case-insensitive operation for non-ASCII characters
+    utl::TransliterationWrapper& rTransliteration = SbGlobal::GetTransliteration();
+
     for( sal_Int32 i = 0 ; i < nCount ; i++ )
     {
         SbxVariable* pVar = xItemArray->Get(i);
-        if( pVar->GetHashCode() == nNameHash &&
-            pVar->GetName().equalsIgnoreAsciiCase( rName ) )
+        if (pVar->GetHashCode() == nNameHash
+            && rTransliteration.isEqual(pVar->GetName(), OUString(rName)))
         {
             nIndex = i;
             break;


More information about the Libreoffice-commits mailing list