Add g_get_locale_variants()

Make _g_compute_locale_variants() public as g_get_locale_variants().

Bug #635998.
This commit is contained in:
Christian Persch 2010-11-28 18:49:04 +01:00
parent be8899bfe6
commit 3d824065b8
6 changed files with 43 additions and 4 deletions

View File

@ -2730,6 +2730,7 @@ g_dpgettext2
g_strip_context g_strip_context
<SUBSECTION> <SUBSECTION>
g_get_language_names g_get_language_names
g_get_locale_variants
</SECTION> </SECTION>
<SECTION> <SECTION>

View File

@ -26,6 +26,7 @@
#include "config.h" #include "config.h"
#include "gkeyfile.h" #include "gkeyfile.h"
#include "gutils.h"
#include <errno.h> #include <errno.h>
#include <fcntl.h> #include <fcntl.h>
@ -1630,8 +1631,6 @@ g_key_file_set_locale_string (GKeyFile *key_file,
g_free (value); g_free (value);
} }
extern gchar **_g_compute_locale_variants (const gchar *locale);
/** /**
* g_key_file_get_locale_string: * g_key_file_get_locale_string:
* @key_file: a #GKeyFile * @key_file: a #GKeyFile
@ -1677,7 +1676,7 @@ g_key_file_get_locale_string (GKeyFile *key_file,
if (locale) if (locale)
{ {
languages = _g_compute_locale_variants (locale); languages = g_get_locale_variants (locale);
free_languages = TRUE; free_languages = TRUE;
} }
else else

View File

@ -1657,6 +1657,7 @@ g_setenv_utf8
g_get_home_dir_utf8 g_get_home_dir_utf8
#endif #endif
g_get_language_names g_get_language_names
g_get_locale_variants
g_get_prgname g_get_prgname
#ifndef _WIN64 #ifndef _WIN64
g_get_real_name PRIVATE g_get_real_name PRIVATE

View File

@ -3201,8 +3201,29 @@ append_locale_variants (GPtrArray *array,
g_free (modifier); g_free (modifier);
} }
/**
* g_get_locale_variants:
* @locale: a locale identifier
*
* Returns a list of derived variants of @locale, which can be used to
* e.g. construct locale-dependent filenames or search paths. The returned
* list is sorted from most desirable to least desirable.
* This function handles territory, charset and extra locale modifiers.
*
* For example, if @locale is "fr_BE", then the returned list
* is "fr_BE", "fr".
*
* If you need the list of variants for the <emphasis>current locale</emphasis>,
* use g_get_language_names().
*
* Returns: (transfer full) (array zero-terminated="1") (element-type utf8): a newly
* allocated array of newly allocated strings with the locale variants. Free with
* g_strfreev().
*
* Since: 2.28
*/
gchar ** gchar **
_g_compute_locale_variants (const gchar *locale) g_get_locale_variants (const gchar *locale)
{ {
GPtrArray *array; GPtrArray *array;

View File

@ -157,6 +157,8 @@ const gchar * g_get_user_runtime_dir (void);
G_CONST_RETURN gchar* G_CONST_RETURN * g_get_language_names (void); G_CONST_RETURN gchar* G_CONST_RETURN * g_get_language_names (void);
gchar **g_get_locale_variants (const gchar *locale);
/** /**
* GUserDirectory: * GUserDirectory:
* @G_USER_DIRECTORY_DESKTOP: the user's Desktop directory * @G_USER_DIRECTORY_DESKTOP: the user's Desktop directory

View File

@ -72,6 +72,20 @@ test_language_names (void)
NULL)); NULL));
} }
static void
test_locale_variants (void)
{
char **v;
v = g_get_locale_variants ("fr_BE");
g_assert (strv_check ((const gchar * const *) v, "fr_BE", "fr", NULL));
g_strfreev (v);
v = g_get_locale_variants ("sr_SR@latin");
g_assert (strv_check ((const gchar * const *) v, "sr_SR@latin", "sr@latin", "sr_SR", "sr", NULL));
g_strfreev (v);
}
static void static void
test_version (void) test_version (void)
{ {
@ -152,6 +166,7 @@ main (int argc,
g_test_bug_base ("http://bugzilla.gnome.org/"); g_test_bug_base ("http://bugzilla.gnome.org/");
g_test_add_func ("/utils/language-names", test_language_names); g_test_add_func ("/utils/language-names", test_language_names);
g_test_add_func ("/utils/locale-variants", test_locale_variants);
g_test_add_func ("/utils/version", test_version); g_test_add_func ("/utils/version", test_version);
g_test_add_func ("/utils/appname", test_appname); g_test_add_func ("/utils/appname", test_appname);
g_test_add_func ("/utils/tmpdir", test_tmpdir); g_test_add_func ("/utils/tmpdir", test_tmpdir);