summaryrefslogtreecommitdiff
path: root/win32/patches/ggettext.c.diff
blob: 7bb8ae8aba5f0b25494146f7307cb4256ccd8a32 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
--- ggettext.c.0	2013-10-25 11:58:38 -0400
+++ ggettext.c	2014-03-23 22:07:29 -0400
@@ -94,17 +94,32 @@
 #endif /* G_OS_WIN32 */
 
 
-static void
+static gboolean
 ensure_gettext_initialized (void)
 {
   static gsize initialised;
 
+#ifdef G_OS_WIN32
+  static GThread * init_thread_atomic;
+  GThread * init_thread = g_atomic_pointer_get (& init_thread_atomic);
+
+  /* avoid deadlock if _glib_get_locale_dir() calls back into gettext */
+  if (G_UNLIKELY (init_thread && init_thread == g_thread_self ()))
+    return FALSE;
+#endif
+
   if (g_once_init_enter (&initialised))
     {
 #ifdef G_OS_WIN32
-      gchar *tmp = _glib_get_locale_dir ();
+      gchar *tmp;
+
+      g_atomic_pointer_set (&init_thread_atomic, g_thread_self ());
+
+      tmp = _glib_get_locale_dir ();
       bindtextdomain (GETTEXT_PACKAGE, tmp);
       g_free (tmp);
+
+      g_atomic_pointer_set (&init_thread_atomic, NULL);
 #else
       bindtextdomain (GETTEXT_PACKAGE, GLIB_LOCALE_DIR);
 #endif
@@ -113,6 +128,8 @@
 #    endif
       g_once_init_leave (&initialised, TRUE);
     }
+
+  return TRUE;
 }
 
 /**
@@ -128,7 +145,8 @@
 const gchar *
 glib_gettext (const gchar *str)
 {
-  ensure_gettext_initialized ();
+  if (G_UNLIKELY (!ensure_gettext_initialized ()))
+    return str;
 
   return g_dgettext (GETTEXT_PACKAGE, str);
 }
@@ -152,7 +170,8 @@
 glib_pgettext (const gchar *msgctxtid,
                gsize        msgidoffset)
 {
-  ensure_gettext_initialized ();
+  if (G_UNLIKELY (!ensure_gettext_initialized ()))
+    return msgctxtid;
 
   return g_dpgettext (GETTEXT_PACKAGE, msgctxtid, msgidoffset);
 }