diff options
| author | Ted Gould <ted@gould.cx> | 2010-07-15 23:28:31 -0500 | 
|---|---|---|
| committer | Ted Gould <ted@gould.cx> | 2010-07-15 23:28:31 -0500 | 
| commit | 189a8a9f03912c6a5da2fa040bca71115be925ee (patch) | |
| tree | 4cee4cbc5fb0d545f9007d6fc50a583866a404e8 /src | |
| parent | 56197266a0a3e82b91138988411d5280c96e4569 (diff) | |
| download | ayatana-indicator-datetime-189a8a9f03912c6a5da2fa040bca71115be925ee.tar.gz ayatana-indicator-datetime-189a8a9f03912c6a5da2fa040bca71115be925ee.tar.bz2 ayatana-indicator-datetime-189a8a9f03912c6a5da2fa040bca71115be925ee.zip | |
Fleshing out the set and get enum functions.
Diffstat (limited to 'src')
| -rw-r--r-- | src/indicator-datetime.c | 33 | 
1 files changed, 30 insertions, 3 deletions
| diff --git a/src/indicator-datetime.c b/src/indicator-datetime.c index eb8394f..97d559c 100644 --- a/src/indicator-datetime.c +++ b/src/indicator-datetime.c @@ -316,18 +316,45 @@ indicator_datetime_finalize (GObject *object)  	return;  } +/* Turns the int value into a string GVariant */  static GVariant *  bind_enum_set (const GValue * value, const GVariantType * type, gpointer user_data)  { - -	return NULL; +	switch (g_value_get_int(value)) { +	case SETTINGS_TIME_LOCALE: +		return g_variant_new_string("locale-default"); +	case SETTINGS_TIME_12_HOUR: +		return g_variant_new_string("12-hour"); +	case SETTINGS_TIME_24_HOUR: +		return g_variant_new_string("24-hour"); +	case SETTINGS_TIME_CUSTOM: +		return g_variant_new_string("custom"); +	default: +		return NULL; +	}  } +/* Turns a string GVariant into an int value */  static gboolean  bind_enum_get (GValue * value, GVariant * variant, gpointer user_data)  { +	const gchar * str = g_variant_get_string(variant, NULL); +	gint output = 0; + +	if (g_strcmp0(str, "locale-default") == 0) { +		output = SETTINGS_TIME_LOCALE; +	} else if (g_strcmp0(str, "12-hour") == 0) { +		output = SETTINGS_TIME_12_HOUR; +	} else if (g_strcmp0(str, "24-hour") == 0) { +		output = SETTINGS_TIME_24_HOUR; +	} else if (g_strcmp0(str, "custom") == 0) { +		output = SETTINGS_TIME_CUSTOM; +	} else { +		return FALSE; +	} -	return FALSE; +	g_value_set_int(value, output); +	return TRUE;  }  static void | 
