diff options
author | ZyX <kp-pav@yandex.ru> | 2017-12-12 00:44:25 +0300 |
---|---|---|
committer | ZyX <kp-pav@yandex.ru> | 2017-12-12 00:44:25 +0300 |
commit | 1f9dd689b9f2b68edbc40cc3c60d46db853dda94 (patch) | |
tree | 1da60fa8fcc4fb8e2a578fac90edae3eb5618202 /src/nvim/os/lang.c | |
parent | 9f534422e6c3649ee40904ae3606455d26b48188 (diff) | |
parent | 8813b29cec13f7410427fbb8913d3753dd6626a7 (diff) | |
download | rneovim-1f9dd689b9f2b68edbc40cc3c60d46db853dda94.tar.gz rneovim-1f9dd689b9f2b68edbc40cc3c60d46db853dda94.tar.bz2 rneovim-1f9dd689b9f2b68edbc40cc3c60d46db853dda94.zip |
Merge branch 'master' into hide-container-impl
Diffstat (limited to 'src/nvim/os/lang.c')
-rw-r--r-- | src/nvim/os/lang.c | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/src/nvim/os/lang.c b/src/nvim/os/lang.c new file mode 100644 index 0000000000..f0bbf4b1cb --- /dev/null +++ b/src/nvim/os/lang.c @@ -0,0 +1,40 @@ +#ifdef __APPLE__ +# define Boolean CFBoolean // Avoid conflict with API's Boolean +# include <CoreFoundation/CFLocale.h> +# include <CoreFoundation/CFString.h> +# undef Boolean +#endif + +#ifdef HAVE_LOCALE_H +# include <locale.h> +#endif +#include "nvim/os/os.h" + +void lang_init(void) +{ +#ifdef __APPLE__ + if (os_getenv("LANG") == NULL) { + CFLocaleRef cf_locale = CFLocaleCopyCurrent(); + CFTypeRef cf_lang_region = CFLocaleGetValue(cf_locale, + kCFLocaleIdentifier); + CFRetain(cf_lang_region); + CFRelease(cf_locale); + + const char *lang_region = CFStringGetCStringPtr(cf_lang_region, + kCFStringEncodingUTF8); + if (lang_region) { + os_setenv("LANG", lang_region, true); + } else { + char buf[20] = { 0 }; + if (CFStringGetCString(cf_lang_region, buf, 20, + kCFStringEncodingUTF8)) { + os_setenv("LANG", lang_region, true); + } + } + CFRelease(cf_lang_region); +# ifdef HAVE_LOCALE_H + setlocale(LC_ALL, ""); +# endif + } +#endif +} |