]> git.wh0rd.org - fontconfig.git/blobdiff - src/fcdefault.c
Use locale data set FC_LANG by default. Reorder FcPattern and FcValueList
[fontconfig.git] / src / fcdefault.c
index 365595dfdc3529b1ba6f2cabcbd653edc4eccfbc..5208746d9bd3234ef9a64dd7e9289fb224055b0f 100644 (file)
@@ -23,6 +23,7 @@
  */
 
 #include "fcint.h"
+#include <locale.h>
 
 static struct {
     char       *field;
@@ -84,4 +85,56 @@ FcDefaultSubstitute (FcPattern *pattern)
        size *= dpi / 72.0;
        FcPatternAddDouble (pattern, FC_PIXEL_SIZE, size);
     }
+
+    if (FcPatternGet (pattern, FC_LANG, 0, &v) == FcResultNoMatch)
+    {
+       char    *lang;
+       char    *territory;
+       char    *after;
+       int     lang_len, territory_len;
+       char    lang_local[128];
+       char    *ctype = setlocale (LC_CTYPE, NULL);
+
+       /*
+        * Check if setlocale (LC_ALL, "") has been called
+        */
+       if (!ctype || !strcmp (ctype, "C"))
+       {
+           ctype = getenv ("LC_ALL");
+           if (!ctype)
+           {
+               ctype = getenv ("LC_CTYPE");
+               if (!ctype)
+                   ctype = getenv ("LANG");
+           }
+       }
+       if (ctype)
+       {
+           lang = ctype;
+           territory = strchr (ctype, '_');
+           if (territory)
+           {
+               lang_len = territory - lang;
+               territory = territory + 1;
+               after = strchr (territory, '.');
+               if (!after)
+               {
+                   after = strchr (territory, '@');
+                   if (!after)
+                       after = territory + strlen (territory);
+               }
+               territory_len = after - territory;
+               if (lang_len + 1 + territory_len + 1 <= sizeof (lang_local))
+               {
+                   strncpy (lang_local, lang, lang_len);
+                   lang_local[lang_len] = '-';
+                   strncpy (lang_local + lang_len + 1, territory, territory_len);
+                   lang_local[lang_len + 1 + territory_len] = '\0';
+                   FcPatternAddString (pattern, FC_LANG, (FcChar8 *) lang_local);
+               }
+           }
+           else
+               FcPatternAddString (pattern, FC_LANG, (FcChar8 *) lang);
+       }
+    }
 }