From 45742f8351e2991d54b00189f6e0c772e257f395 Mon Sep 17 00:00:00 2001 From: Stefano Karapetsas Date: Wed, 5 Sep 2012 21:43:27 +0200 Subject: convert last eel_preference users to raw mateconf from nautilus patch: This is moslty the lockdown stuff, but we also access the background setting. This should be converted to use the new gsettings when they land. --- libcaja-private/caja-global-preferences.c | 255 ++------------------------- libcaja-private/caja-global-preferences.h | 4 + libcaja-private/org.mate.caja.gschema.xml.in | 2 +- 3 files changed, 15 insertions(+), 246 deletions(-) (limited to 'libcaja-private') diff --git a/libcaja-private/caja-global-preferences.c b/libcaja-private/caja-global-preferences.c index 64e47ee2..7465add7 100644 --- a/libcaja-private/caja-global-preferences.c +++ b/libcaja-private/caja-global-preferences.c @@ -40,17 +40,12 @@ #define PREFERENCES_SORT_ORDER_MANUALLY 100 /* Path for mate-vfs preferences */ -static const char *EXTRA_MONITOR_PATHS[] = { "/desktop/mate/file_views", +static const char *EXTRA_MONITOR_PATHS[] = { "/desktop/mate/background", "/desktop/mate/lockdown", NULL }; -/* Forward declarations */ -static void global_preferences_install_defaults (void); -static void global_preferences_register_enumerations (void); - - /* An enumeration used for installing type specific preferences defaults. */ typedef enum { @@ -60,51 +55,6 @@ typedef enum PREFERENCE_STRING_ARRAY } PreferenceType; -static EelEnumerationEntry default_zoom_level_enum_entries[] = -{ - /* xgettext:no-c-format */ - { "smallest", N_("25%"), CAJA_ZOOM_LEVEL_SMALLEST }, - /* xgettext:no-c-format */ - { "smaller", N_("50%"), CAJA_ZOOM_LEVEL_SMALLER }, - /* xgettext:no-c-format */ - { "small", N_("75%"), CAJA_ZOOM_LEVEL_SMALL }, - /* xgettext:no-c-format */ - { "standard", N_("100%"), CAJA_ZOOM_LEVEL_STANDARD }, - /* xgettext:no-c-format */ - { "large", N_("150%"), CAJA_ZOOM_LEVEL_LARGE }, - /* xgettext:no-c-format */ - { "larger", N_("200%"), CAJA_ZOOM_LEVEL_LARGER }, - /* xgettext:no-c-format */ - { "largest", N_("400%"), CAJA_ZOOM_LEVEL_LARGEST } -}; - -static EelEnumerationEntry file_size_enum_entries[] = -{ - { "102400", N_("100 K"), 102400 }, - { "512000", N_("500 K"), 512000 }, - { "1048576", N_("1 MB"), 1048576 }, - { "3145728", N_("3 MB"), 3145728 }, - { "5242880", N_("5 MB"), 5242880 }, - { "10485760", N_("10 MB"), 10485760 }, - { "104857600", N_("100 MB"), 104857600 }, - { "1073741824", N_("1 GB"), 1073741824 }, - { "2147483648", N_("2 GB"), 2147483648U }, - { "4294967295", N_("4 GB"), 4294967295U } -}; - -static EelEnumerationEntry standard_font_size_entries[] = -{ - { "8", N_("8"), 8 }, - { "10", N_("10"), 10 }, - { "12", N_("12"), 12 }, - { "14", N_("14"), 14 }, - { "16", N_("16"), 16 }, - { "18", N_("18"), 18 }, - { "20", N_("20"), 20 }, - { "22", N_("22"), 22 }, - { "24", N_("24"), 24 } -}; - /* * A callback which can be used to fetch dynamic fallback values. * For example, values that are dependent on the environment (such as user name) @@ -123,184 +73,6 @@ typedef struct const char *enumeration_id; } PreferenceDefault; -/* The following table defines the default values and user level visibilities of - * Caja preferences. Each of these preferences does not necessarily need to - * have a UI item in the preferences dialog. To add an item to the preferences - * dialog, see the CajaPreferencesItemDescription tables later in this file. - * - * Field definitions: - * - * 1. name - * - * The name of the preference. Usually defined in - * caja-global-preferences.h - * - * 2. type - * The preference type. One of: - * - * PREFERENCE_BOOLEAN - * PREFERENCE_INTEGER - * PREFERENCE_STRING - * PREFERENCE_STRING_ARRAY - * - * 3. fallback_value - * Emergency fallback value if our mateconf schemas are hosed somehow. - * - * 4. fallback_callback - * callback to get dynamic fallback - * - * 5. fallback_callback_result_free_function - * free result of fallback_callback - * - * 6. enumeration_id - * An an enumeration id is a unique string that identifies an enumeration. - * If given, an enumeration id can be used to qualify a INTEGER preference. - * The preferences dialog widgetry will use this enumeration id to find out - * what choices and descriptions of choices to present to the user. - */ - -/* NOTE THAT THE FALLBACKS HERE ARE NOT SUPPOSED TO BE USED - - * YOU SHOULD EDIT THE SCHEMAS FILE TO CHANGE DEFAULTS. - */ -static const PreferenceDefault preference_defaults[] = -{ - { - CAJA_PREFERENCES_LOCKDOWN_COMMAND_LINE, - PREFERENCE_BOOLEAN, - GINT_TO_POINTER (FALSE) - }, - { NULL } -}; - - -/** - * global_preferences_register_enumerations - * - * Register enumerations for INTEGER preferences that need them. - * - * This function needs to be called before the preferences dialog - * panes are populated, as they use the registered information to - * create enumeration item widgets. - */ -static void -global_preferences_register_enumerations (void) -{ - guint i; - - /* Register the enumerations. - * These enumerations are used in the preferences dialog to - * populate widgets and route preferences changes between the - * storage (MateConf) and the displayed values. - */ - eel_enumeration_register ("default_zoom_level", - default_zoom_level_enum_entries, - G_N_ELEMENTS (default_zoom_level_enum_entries)); - eel_enumeration_register ("file_size", - file_size_enum_entries, - G_N_ELEMENTS (file_size_enum_entries)); - eel_enumeration_register ("standard_font_size", - standard_font_size_entries, - G_N_ELEMENTS (standard_font_size_entries)); - - /* Set the enumeration ids for preferences that need them */ - for (i = 0; preference_defaults[i].name != NULL; i++) - { - if (eel_strlen (preference_defaults[i].enumeration_id) > 0) - { - g_assert (preference_defaults[i].type == PREFERENCE_STRING - || preference_defaults[i].type == PREFERENCE_STRING_ARRAY - || preference_defaults[i].type == PREFERENCE_INTEGER); - eel_preferences_set_enumeration_id (preference_defaults[i].name, - preference_defaults[i].enumeration_id); - } - } -} - -static void -global_preferences_install_one_default (const char *preference_name, - PreferenceType preference_type, - const PreferenceDefault *preference_default) -{ - gpointer value = NULL; - char **string_array_value; - - g_return_if_fail (preference_name != NULL); - g_return_if_fail (preference_type >= PREFERENCE_BOOLEAN); - g_return_if_fail (preference_type <= PREFERENCE_STRING_ARRAY); - g_return_if_fail (preference_default != NULL); - - /* If a callback is given, use that to fetch the default value */ - if (preference_default->fallback_callback != NULL) - { - value = (* preference_default->fallback_callback) (); - } - else - { - value = preference_default->fallback_value; - } - - switch (preference_type) - { - case PREFERENCE_BOOLEAN: - eel_preferences_set_emergency_fallback_boolean (preference_name, - GPOINTER_TO_INT (value)); - break; - - case PREFERENCE_INTEGER: - eel_preferences_set_emergency_fallback_integer (preference_name, - - GPOINTER_TO_INT (value)); - break; - - case PREFERENCE_STRING: - eel_preferences_set_emergency_fallback_string (preference_name, - value); - break; - - case PREFERENCE_STRING_ARRAY: - string_array_value = g_strsplit (value, - STRING_ARRAY_DEFAULT_TOKENS_DELIMETER, - -1); - eel_preferences_set_emergency_fallback_string_array (preference_name, - string_array_value); - g_strfreev (string_array_value); - break; - - default: - g_assert_not_reached (); - } - - /* Free the dynamic default value if needed */ - if (preference_default->fallback_callback != NULL - && preference_default->fallback_callback_result_free_function != NULL) - { - (* preference_default->fallback_callback_result_free_function) (value); - } -} - -/** - * global_preferences_install_defaults - * - * Install defaults and visibilities. - * - * Most of the defaults come from the preference_defaults table above. - * - * Many preferences require their defaults to be computed, and so there - * are special functions to install those. - */ -static void -global_preferences_install_defaults (void) -{ - guint i; - - for (i = 0; preference_defaults[i].name != NULL; i++) - { - global_preferences_install_one_default (preference_defaults[i].name, - preference_defaults[i].type, - &preference_defaults[i]); - } -} - /* * Public functions */ @@ -343,17 +115,6 @@ caja_global_preferences_init (void) initialized = TRUE; eel_preferences_init ("/apps/caja"); - - /* Install defaults */ - global_preferences_install_defaults (); - - global_preferences_register_enumerations (); - - /* Add monitors for any other MateConf paths we have keys in */ - for (i=0; EXTRA_MONITOR_PATHS[i] != NULL; i++) - { - eel_preferences_monitor_directory (EXTRA_MONITOR_PATHS[i]); - } caja_preferences = g_settings_new("org.mate.caja.preferences"); caja_media_preferences = g_settings_new("org.mate.media-handling"); @@ -364,11 +125,15 @@ caja_global_preferences_init (void) caja_tree_sidebar_preferences = g_settings_new("org.mate.caja.sidebar-panels.tree"); caja_list_view_preferences = g_settings_new("org.mate.caja.list-view"); - /* Set up storage for values accessed in this file */ - g_signal_connect_swapped (caja_icon_view_preferences, - "changed::" CAJA_PREFERENCES_ICON_VIEW_DEFAULT_SORT_ORDER_OR_MANUAL_LAYOUT, - G_CALLBACK (default_icon_view_sort_order_or_manual_layout_changed_callback), - NULL); + caja_mateconf_client = mateconf_client_get_default (); + + /* Add monitors for any other MateConf paths we have keys in */ + for (i=0; EXTRA_MONITOR_PATHS[i] != NULL; i++) { + mateconf_client_add_dir (caja_mateconf_client, + EXTRA_MONITOR_PATHS[i], + MATECONF_CLIENT_PRELOAD_ONELEVEL, + NULL); + } /* Preload everything in a big batch */ eel_mateconf_preload_cache ("/apps/caja/preferences", diff --git a/libcaja-private/caja-global-preferences.h b/libcaja-private/caja-global-preferences.h index ab961cb9..41935192 100644 --- a/libcaja-private/caja-global-preferences.h +++ b/libcaja-private/caja-global-preferences.h @@ -207,6 +207,8 @@ G_BEGIN_DECLS /* Lockdown */ #define CAJA_PREFERENCES_LOCKDOWN_COMMAND_LINE "/desktop/mate/lockdown/disable_command_line" +#define CAJA_MATECONF_LOCKDOWN_COMMAND_LINE "/desktop/mate/lockdown/disable_command_line" + void caja_global_preferences_init (void); char *caja_global_preferences_get_default_folder_viewer_preference_as_iid (void); @@ -220,6 +222,8 @@ GSettings *caja_tree_sidebar_preferences; GSettings *caja_compact_view_preferences; GSettings *caja_list_view_preferences; +MateConfClient *caja_mateconf_client; + G_END_DECLS #endif /* CAJA_GLOBAL_PREFERENCES_H */ diff --git a/libcaja-private/org.mate.caja.gschema.xml.in b/libcaja-private/org.mate.caja.gschema.xml.in index 1885fdea..d9dd79c3 100644 --- a/libcaja-private/org.mate.caja.gschema.xml.in +++ b/libcaja-private/org.mate.caja.gschema.xml.in @@ -168,7 +168,7 @@ <_summary>Show folders first in windows <_description>If set to true, then Caja shows folders prior to showing files in the icon and list views. - + -- cgit v1.2.1