mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-13 15:56:23 +01:00
GSettings: add getters for user/default value
Add two new APIs: g_settings_get_user_value() and g_settings_get_default_value(). Together, these should allow the inspection of all interesting cases of "is this key set?" and "what would happen if I reset this key?" https://bugzilla.gnome.org/show_bug.cgi?id=668233
This commit is contained in:
parent
2d06dbeef1
commit
bebdfb8e62
@ -2442,6 +2442,8 @@ g_settings_revert
|
|||||||
g_settings_get_has_unapplied
|
g_settings_get_has_unapplied
|
||||||
g_settings_get_child
|
g_settings_get_child
|
||||||
g_settings_reset
|
g_settings_reset
|
||||||
|
g_settings_get_user_value
|
||||||
|
g_settings_get_default_value
|
||||||
|
|
||||||
<SUBSECTION Introspection>
|
<SUBSECTION Introspection>
|
||||||
g_settings_list_schemas
|
g_settings_list_schemas
|
||||||
|
100
gio/gsettings.c
100
gio/gsettings.c
@ -1113,6 +1113,106 @@ g_settings_get_value (GSettings *settings,
|
|||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* g_settings_get_user_value:
|
||||||
|
* @settings: a #GSettings object
|
||||||
|
* @key: the key to check for being set
|
||||||
|
*
|
||||||
|
* Checks the "user value" of a key, if there is one.
|
||||||
|
*
|
||||||
|
* The user value of a key is the last value that was set by the user.
|
||||||
|
*
|
||||||
|
* After calling g_settings_reset() this function should always return
|
||||||
|
* %NULL (assuming something is not wrong with the system
|
||||||
|
* configuration).
|
||||||
|
*
|
||||||
|
* It is possible that g_settings_get_value() will return a different
|
||||||
|
* value than this function. This can happen in the case that the user
|
||||||
|
* set a value for a key that was subsequently locked down by the system
|
||||||
|
* administrator -- this function will return the user's old value.
|
||||||
|
*
|
||||||
|
* This function may be useful for adding a "reset" option to a UI or
|
||||||
|
* for providing indication that a particular value has been changed.
|
||||||
|
*
|
||||||
|
* It is a programmer error to give a @key that isn't contained in the
|
||||||
|
* schema for @settings.
|
||||||
|
*
|
||||||
|
* Returns: (allow none) (transfer full): the user's value, if set
|
||||||
|
*
|
||||||
|
* Since: 2.40
|
||||||
|
**/
|
||||||
|
GVariant *
|
||||||
|
g_settings_get_user_value (GSettings *settings,
|
||||||
|
const gchar *key)
|
||||||
|
{
|
||||||
|
GSettingsSchemaKey skey;
|
||||||
|
GVariant *value;
|
||||||
|
|
||||||
|
g_return_val_if_fail (G_IS_SETTINGS (settings), NULL);
|
||||||
|
g_return_val_if_fail (key != NULL, NULL);
|
||||||
|
|
||||||
|
g_settings_schema_key_init (&skey, settings->priv->schema, key);
|
||||||
|
value = g_settings_read_from_backend (settings, &skey, TRUE, FALSE);
|
||||||
|
g_settings_schema_key_clear (&skey);
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* g_settings_get_default_value:
|
||||||
|
* @settings: a #GSettings object
|
||||||
|
* @key: the key to check for being set
|
||||||
|
*
|
||||||
|
* Gets the "default value" of a key.
|
||||||
|
*
|
||||||
|
* This is the value that would be read if g_settings_reset() were to be
|
||||||
|
* called on the key.
|
||||||
|
*
|
||||||
|
* Note that this may be a different value than returned by
|
||||||
|
* g_settings_schema_key_get_default_value() if the system administrator
|
||||||
|
* has provided a default value.
|
||||||
|
*
|
||||||
|
* Comparing the return values of g_settings_get_default_value() and
|
||||||
|
* g_settings_get_value() is not sufficient for determining if a value
|
||||||
|
* has been set because the user may have explicitly set the value to
|
||||||
|
* something that happens to be equal to the default. The difference
|
||||||
|
* here is that if the default changes in the future, the user's key
|
||||||
|
* will still be set.
|
||||||
|
*
|
||||||
|
* This function may be useful for adding an indication to a UI of what
|
||||||
|
* the default value was before the user set it.
|
||||||
|
*
|
||||||
|
* It is a programmer error to give a @key that isn't contained in the
|
||||||
|
* schema for @settings.
|
||||||
|
*
|
||||||
|
* Returns: (allow none) (transfer full): the default value
|
||||||
|
*
|
||||||
|
* Since: 2.40
|
||||||
|
**/
|
||||||
|
GVariant *
|
||||||
|
g_settings_get_default_value (GSettings *settings,
|
||||||
|
const gchar *key)
|
||||||
|
{
|
||||||
|
GSettingsSchemaKey skey;
|
||||||
|
GVariant *value;
|
||||||
|
|
||||||
|
g_return_val_if_fail (G_IS_SETTINGS (settings), NULL);
|
||||||
|
g_return_val_if_fail (key != NULL, NULL);
|
||||||
|
|
||||||
|
g_settings_schema_key_init (&skey, settings->priv->schema, key);
|
||||||
|
value = g_settings_read_from_backend (settings, &skey, FALSE, TRUE);
|
||||||
|
|
||||||
|
if (value == NULL)
|
||||||
|
value = g_settings_schema_key_get_translated_default (&skey);
|
||||||
|
|
||||||
|
if (value == NULL)
|
||||||
|
value = g_variant_ref (skey.default_value);
|
||||||
|
|
||||||
|
g_settings_schema_key_clear (&skey);
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_settings_get_enum:
|
* g_settings_get_enum:
|
||||||
* @settings: a #GSettings object
|
* @settings: a #GSettings object
|
||||||
|
@ -112,6 +112,13 @@ GLIB_AVAILABLE_IN_ALL
|
|||||||
GVariant * g_settings_get_value (GSettings *settings,
|
GVariant * g_settings_get_value (GSettings *settings,
|
||||||
const gchar *key);
|
const gchar *key);
|
||||||
|
|
||||||
|
GLIB_AVAILABLE_IN_2_40
|
||||||
|
GVariant * g_settings_get_user_value (GSettings *settings,
|
||||||
|
const gchar *key);
|
||||||
|
GLIB_AVAILABLE_IN_2_40
|
||||||
|
GVariant * g_settings_get_default_value (GSettings *settings,
|
||||||
|
const gchar *key);
|
||||||
|
|
||||||
GLIB_AVAILABLE_IN_ALL
|
GLIB_AVAILABLE_IN_ALL
|
||||||
gboolean g_settings_set (GSettings *settings,
|
gboolean g_settings_set (GSettings *settings,
|
||||||
const gchar *key,
|
const gchar *key,
|
||||||
|
Loading…
Reference in New Issue
Block a user