summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFederico Mena Quintero <federico@gnome.org>2021-07-01 19:31:05 -0500
committerFederico Mena Quintero <federico@gnome.org>2021-07-01 19:32:32 -0500
commit384f0e1530d36a1ac4bb95c3666a708927ec4f0c (patch)
tree6c9f083597f6b5e88cf7d63f80f4783c71525ce9
parent27210a3039144e5ac15c1cd902591168805e09d9 (diff)
downloadpango-384f0e1530d36a1ac4bb95c3666a708927ec4f0c.tar.gz
Use an enum instead of numeric values for fc_initialized
-rw-r--r--pango/pangofc-fontmap.c21
1 files changed, 16 insertions, 5 deletions
diff --git a/pango/pangofc-fontmap.c b/pango/pangofc-fontmap.c
index 4be8502e..7ea5dc52 100644
--- a/pango/pangofc-fontmap.c
+++ b/pango/pangofc-fontmap.c
@@ -100,13 +100,24 @@
* FcCharSetMerge().
*/
+typedef enum {
+ /* Initial state; Fontconfig is not initialized yet */
+ DEFAULT_CONFIG_NOT_INITIALIZED,
+
+ /* We have a thread doing Fontconfig initialization in the background */
+ DEFAULT_CONFIG_INITIALIZING,
+
+ /* FcInit() finished and its default configuration is loaded */
+ DEFAULT_CONFIG_INITIALIZED
+} DefaultConfig;
+
/* We call FcInit in a thread and set fc_initialized
* when done, and are protected by a mutex. The thread
* signals the cond when FcInit is done.
*/
static GMutex fc_init_mutex;
static GCond fc_init_cond;
-static int fc_initialized = 0;
+static DefaultConfig fc_initialized = DEFAULT_CONFIG_NOT_INITIALIZED;
typedef struct _PangoFcFontFaceData PangoFcFontFaceData;
@@ -1342,7 +1353,7 @@ init_in_thread (gpointer task_data)
pango_trace_mark (before, "FcInit", NULL);
g_mutex_lock (&fc_init_mutex);
- fc_initialized = 2;
+ fc_initialized = DEFAULT_CONFIG_INITIALIZED;
g_cond_broadcast (&fc_init_cond);
g_mutex_unlock (&fc_init_mutex);
@@ -1354,11 +1365,11 @@ start_init_in_thread (PangoFcFontMap *fcfontmap)
{
g_mutex_lock (&fc_init_mutex);
- if (fc_initialized == 0)
+ if (fc_initialized == DEFAULT_CONFIG_NOT_INITIALIZED)
{
GThread *thread;
- fc_initialized = 1;
+ fc_initialized = DEFAULT_CONFIG_INITIALIZING;
thread = g_thread_new ("[pango] FcInit", init_in_thread, NULL);
g_thread_unref (thread);
}
@@ -1373,7 +1384,7 @@ wait_for_fc_init (void)
gboolean waited = FALSE;
g_mutex_lock (&fc_init_mutex);
- while (fc_initialized < 2)
+ while (fc_initialized < DEFAULT_CONFIG_INITIALIZED)
{
waited = TRUE;
g_cond_wait (&fc_init_cond, &fc_init_mutex);