aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/os/lang.c
diff options
context:
space:
mode:
authorZyX <kp-pav@yandex.ru>2017-12-12 00:44:25 +0300
committerZyX <kp-pav@yandex.ru>2017-12-12 00:44:25 +0300
commit1f9dd689b9f2b68edbc40cc3c60d46db853dda94 (patch)
tree1da60fa8fcc4fb8e2a578fac90edae3eb5618202 /src/nvim/os/lang.c
parent9f534422e6c3649ee40904ae3606455d26b48188 (diff)
parent8813b29cec13f7410427fbb8913d3753dd6626a7 (diff)
downloadrneovim-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.c40
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
+}