[Libreoffice-commits] core.git: i18nlangtag/source include/i18nlangtag

Eike Rathke erack at redhat.com
Tue Jul 9 11:02:47 PDT 2013


 i18nlangtag/source/languagetag/languagetag.cxx |   58 ++++++++++++++++++-------
 include/i18nlangtag/languagetag.hxx            |    7 +++
 2 files changed, 49 insertions(+), 16 deletions(-)

New commits:
commit 467cef426a84604263923d654213e14b4d29bbef
Author: Eike Rathke <erack at redhat.com>
Date:   Tue Jul 9 19:58:48 2013 +0200

    let getLanguageType() resolve unknown due to present default script
    
    Change-Id: I54170c7f2183ec2615aca875031148c85c939108

diff --git a/i18nlangtag/source/languagetag/languagetag.cxx b/i18nlangtag/source/languagetag/languagetag.cxx
index 673960f..7d47580 100644
--- a/i18nlangtag/source/languagetag/languagetag.cxx
+++ b/i18nlangtag/source/languagetag/languagetag.cxx
@@ -433,6 +433,8 @@ bool LanguageTag::canonicalize()
     dumper aDumper( &mpImplLangtag);
 #endif
 
+    bool bChanged = false;
+
     // Side effect: have maBcp47 in any case, resolved system.
     // Some methods calling canonicalize() (or not calling it due to
     // meIsLiblangtagNeeded==DECISION_NO) rely on this! Hence do not set
@@ -517,7 +519,7 @@ bool LanguageTag::canonicalize()
     if (meIsLiblangtagNeeded == DECISION_NO)
     {
         meIsValid = DECISION_YES;   // really, known must be valid ...
-        return true;                // that's it
+        return bChanged;            // that's it
     }
     meIsLiblangtagNeeded = DECISION_YES;
     SAL_INFO( "i18nlangtag", "LanguageTag::canonicalize: using liblangtag for " << maBcp47);
@@ -542,17 +544,20 @@ bool LanguageTag::canonicalize()
             // removes default script and such.
             if (maBcp47 != aOld)
             {
+                bChanged = true;
+                meIsIsoLocale = DECISION_DONTKNOW;
+                meIsIsoODF = DECISION_DONTKNOW;
                 if (!lt_tag_parse( MPLANGTAG, pTag, &aError.p))
                 {
                     SAL_WARN( "i18nlangtag", "LanguageTag::canonicalize: could not reparse " << maBcp47);
                     free( pTag);
                     meIsValid = DECISION_NO;
-                    return false;
+                    return bChanged;
                 }
             }
             free( pTag);
             meIsValid = DECISION_YES;
-            return true;
+            return bChanged;
         }
     }
     else
@@ -560,7 +565,25 @@ bool LanguageTag::canonicalize()
         SAL_INFO( "i18nlangtag", "LanguageTag::canonicalize: could not parse " << maBcp47);
     }
     meIsValid = DECISION_NO;
-    return false;
+    return bChanged;
+}
+
+
+bool LanguageTag::synCanonicalize()
+{
+    bool bChanged = false;
+    if (meIsLiblangtagNeeded != DECISION_NO && !mpImplLangtag)
+    {
+        bChanged = canonicalize();
+        if (bChanged)
+        {
+            if (mbInitializedLocale)
+                convertBcp47ToLocale();
+            if (mbInitializedLangID)
+                convertBcp47ToLang();
+        }
+    }
+    return bChanged;
 }
 
 
@@ -733,8 +756,7 @@ const OUString & LanguageTag::getBcp47( bool bResolveSystem ) const
 OUString LanguageTag::getLanguageFromLangtag()
 {
     OUString aLanguage;
-    if (meIsLiblangtagNeeded != DECISION_NO && !mpImplLangtag)
-        canonicalize();
+    synCanonicalize();
     if (maBcp47.isEmpty())
         return aLanguage;
     if (mpImplLangtag)
@@ -760,8 +782,7 @@ OUString LanguageTag::getLanguageFromLangtag()
 OUString LanguageTag::getScriptFromLangtag()
 {
     OUString aScript;
-    if (meIsLiblangtagNeeded != DECISION_NO && !mpImplLangtag)
-        canonicalize();
+    synCanonicalize();
     if (maBcp47.isEmpty())
         return aScript;
     if (mpImplLangtag)
@@ -787,8 +808,7 @@ OUString LanguageTag::getScriptFromLangtag()
 OUString LanguageTag::getRegionFromLangtag()
 {
     OUString aRegion;
-    if (meIsLiblangtagNeeded != DECISION_NO && !mpImplLangtag)
-        canonicalize();
+    synCanonicalize();
     if (maBcp47.isEmpty())
         return aRegion;
     if (mpImplLangtag)
@@ -842,7 +862,16 @@ LanguageType LanguageTag::getLanguageType( bool bResolveSystem ) const
         if (mbInitializedBcp47)
             const_cast<LanguageTag*>(this)->convertBcp47ToLang();
         else
+        {
             const_cast<LanguageTag*>(this)->convertLocaleToLang();
+
+            /* Resolve a locale only unknown due to some redundant information,
+             * like 'de-Latn-DE' with script tag. Never call canonicalize()
+             * from within convert...() methods due to possible recursion, so
+             * do it here. */
+            if ((!mbSystemLocale && mnLangID == LANGUAGE_SYSTEM) || mnLangID == LANGUAGE_DONTKNOW)
+                const_cast<LanguageTag*>(this)->synCanonicalize();
+        }
     }
     return mnLangID;
 }
@@ -1030,8 +1059,7 @@ bool LanguageTag::isIsoLocale() const
 {
     if (meIsIsoLocale == DECISION_DONTKNOW)
     {
-        if (meIsLiblangtagNeeded != DECISION_NO && !mpImplLangtag)
-            const_cast<LanguageTag*>(this)->canonicalize();
+        const_cast<LanguageTag*>(this)->synCanonicalize();
         // It must be at most ll-CC or lll-CC
         // Do not use getCountry() here, use getRegion() instead.
         meIsIsoLocale = ((maBcp47.isEmpty() ||
@@ -1046,8 +1074,7 @@ bool LanguageTag::isIsoODF() const
 {
     if (meIsIsoODF == DECISION_DONTKNOW)
     {
-        if (meIsLiblangtagNeeded != DECISION_NO && !mpImplLangtag)
-            const_cast<LanguageTag*>(this)->canonicalize();
+        const_cast<LanguageTag*>(this)->synCanonicalize();
         if (!isIsoScript( getScript()))
             return ((meIsIsoODF = DECISION_NO) == DECISION_YES);
         // The usual case is lll-CC so simply check that first.
@@ -1067,8 +1094,7 @@ bool LanguageTag::isValidBcp47() const
 {
     if (meIsValid == DECISION_DONTKNOW)
     {
-        if (meIsLiblangtagNeeded != DECISION_NO && !mpImplLangtag)
-           const_cast<LanguageTag*>(this)->canonicalize();
+        const_cast<LanguageTag*>(this)->synCanonicalize();
         SAL_WARN_IF( meIsValid == DECISION_DONTKNOW, "i18nlangtag",
                 "LanguageTag::isValidBcp47: canonicalize() didn't set meIsValid");
     }
diff --git a/include/i18nlangtag/languagetag.hxx b/include/i18nlangtag/languagetag.hxx
index 7fa9b96..8f23098 100644
--- a/include/i18nlangtag/languagetag.hxx
+++ b/include/i18nlangtag/languagetag.hxx
@@ -376,8 +376,15 @@ private:
 
     void    convertFromRtlLocale();
 
+    /** @return whether BCP 47 language tag string was changed. */
     bool    canonicalize();
 
+    /** Canonicalize if not yet done and synchronize initialized conversions.
+
+        @return whether BCP 47 language tag string was changed.
+     */
+    bool    synCanonicalize();
+
     OUString    getLanguageFromLangtag();
     OUString    getScriptFromLangtag();
     OUString    getRegionFromLangtag();


More information about the Libreoffice-commits mailing list