]> git.saurik.com Git - apt.git/commitdiff
* apt-pkg/indexfile.cc:
authorMichael Vogt <michael.vogt@ubuntu.com>
Fri, 12 Mar 2010 21:06:08 +0000 (22:06 +0100)
committerMichael Vogt <michael.vogt@ubuntu.com>
Fri, 12 Mar 2010 21:06:08 +0000 (22:06 +0100)
  - deal correctly with three letter langcodes (LP: #391409)

apt-pkg/indexfile.cc
debian/changelog

index 08f71feb0e81be15b43f3234ab20fdbe85a484a7..34fd71b20197473ec4fefba739dea80263598a68 100644 (file)
@@ -89,8 +89,11 @@ bool pkgIndexFile::TranslationsAvailable()
 
 bool pkgIndexFile::CheckLanguageCode(const char *Lang)
 {
-  if (strlen(Lang) == 2 || (strlen(Lang) == 5 && Lang[2] == '_'))
-    return true;
+  if (strlen(Lang) == 2 || 
+      strlen(Lang) == 3 ||
+      (strlen(Lang) > 3 && Lang[3] == '_') ||
+      (strlen(Lang) == 5 && Lang[2] == '_'))
+  return true;
 
   if (strcmp(Lang,"C") != 0)
     _error->Warning("Wrong language code %s", Lang);
@@ -112,13 +115,18 @@ string pkgIndexFile::LanguageCode()
      // we have a mapping of the language codes that contains all the language
      // codes that need the country code as well 
      // (like pt_BR, pt_PT, sv_SE, zh_*, en_*)
-     const char *need_full_langcode[] = { "pt","sv","zh","en", NULL };
+     const char *need_full_langcode[] = { "cs_", 
+                                         "en_", 
+                                         "pt_",
+                                         "sv_",
+                                         "zh_", 
+                                         NULL };
      for(const char **s = need_full_langcode;*s != NULL; s++)
        if(lang.find(*s) == 0)
           return lang.substr(0,5);
      
-     if(lang.size() > 2)
-       return lang.substr(0,2);
+     if(lang.find("_") != lang.npos)
+       return lang.substr(0, lang.find("_"));
      else
        return lang;
   }
index 9665cd2d199e194a5407e2ae8b8f8f877a9a829c..6a078c498e4f4449c2d493676ef20110cec3541f 100644 (file)
@@ -25,6 +25,8 @@ apt (0.7.25.4) UNRELEASED; urgency=low
   * cmdline/apt-get.cc:
     - if apt-get source foo=version or foo/distro can not be found,
       error out (LP: #502641)
+  * apt-pkg/indexfile.cc:
+    - deal correctly with three letter langcodes (LP: #391409)
 
   [ Robert Collins ]
   * Change the package index Info methods to allow apt-cache policy to be