Commit b37993dbeb8d6fb44eded52792214052f0af5d76
1 parent
33b69d25
Exists in
master
and in
1 other branch
Fixing keyfile manager.
Showing
3 changed files
with
92 additions
and
6 deletions
Show diff stats
src/include/v3270/settings.h
| ... | ... | @@ -38,14 +38,14 @@ |
| 38 | 38 | /*--[ Tools ]----------------------------------------------------------------------------------------*/ |
| 39 | 39 | |
| 40 | 40 | /// @brief Reads the terminal settings from the group group_name in key_file. |
| 41 | - LIB3270_EXPORT gboolean v3270_load_key_file(GtkWidget *widget, GKeyFile *key_file, const gchar *group_name, GError **error); | |
| 41 | + LIB3270_EXPORT gboolean v3270_load_key_file(GtkWidget *widget, GKeyFile *key_file, const gchar *group_name); | |
| 42 | 42 | |
| 43 | 43 | /// @brief This function adds the terminal settings from widget to key_file. |
| 44 | 44 | LIB3270_EXPORT void v3270_to_key_file(GtkWidget *widget, GKeyFile *key_file, const gchar *group_name); |
| 45 | 45 | |
| 46 | 46 | #ifdef _WIN32 |
| 47 | 47 | |
| 48 | - LIB3270_EXPORT gboolean v3270_load_registry(GtkWidget *widget, HKEY *key, const gchar *group_name, GError **error); | |
| 48 | + LIB3270_EXPORT gboolean v3270_load_registry(GtkWidget *widget, HKEY *key, const gchar *group_name); | |
| 49 | 49 | |
| 50 | 50 | LIB3270_EXPORT void v3270_to_registry(GtkWidget *widget, HKEY *key, const gchar *group_name); |
| 51 | 51 | ... | ... |
src/terminal/keyfile.c
| ... | ... | @@ -51,7 +51,9 @@ |
| 51 | 51 | { |
| 52 | 52 | const gchar * current = g_value_get_string(&value); |
| 53 | 53 | |
| 54 | - if(current && G_PARAM_SPEC_STRING(pspec)->default_value && strcmp(current,G_PARAM_SPEC_STRING(pspec)->default_value)) | |
| 54 | + debug("%s=%s (default: %s)",name,current,G_PARAM_SPEC_STRING(pspec)->default_value); | |
| 55 | + | |
| 56 | + if(current && strcmp(current,G_PARAM_SPEC_STRING(pspec)->default_value ? G_PARAM_SPEC_STRING(pspec)->default_value : "")) | |
| 55 | 57 | { |
| 56 | 58 | g_key_file_set_string( |
| 57 | 59 | key_file, |
| ... | ... | @@ -156,6 +158,53 @@ |
| 156 | 158 | |
| 157 | 159 | g_value_unset(&value); |
| 158 | 160 | |
| 161 | + } | |
| 162 | + | |
| 163 | + static void load_by_pspec(GtkWidget *widget, GParamSpec *pspec, GKeyFile *key_file, const gchar *group_name) | |
| 164 | + { | |
| 165 | + const gchar * name = g_param_spec_get_name(pspec); | |
| 166 | + GError * error = NULL; | |
| 167 | + | |
| 168 | + if(!g_key_file_has_key(key_file,group_name,name,&error)) | |
| 169 | + { | |
| 170 | + if(error) | |
| 171 | + { | |
| 172 | + g_message("%s::%s: %s",group_name,name,error->message); | |
| 173 | + g_error_free(error); | |
| 174 | + } | |
| 175 | + return; | |
| 176 | + } | |
| 177 | + | |
| 178 | + GValue value = G_VALUE_INIT; | |
| 179 | + g_value_init(&value, pspec->value_type); | |
| 180 | + | |
| 181 | + switch(pspec->value_type) | |
| 182 | + { | |
| 183 | + case G_TYPE_STRING: | |
| 184 | + g_value_set_string(&value, g_key_file_get_string(key_file,group_name,name,NULL)); | |
| 185 | + break; | |
| 186 | + | |
| 187 | + case G_TYPE_BOOLEAN: | |
| 188 | + g_value_set_boolean(&value, g_key_file_get_boolean(key_file,group_name,name,NULL)); | |
| 189 | + break; | |
| 190 | + | |
| 191 | + case G_TYPE_INT: | |
| 192 | + g_value_set_int(&value, g_key_file_get_integer(key_file,group_name,name,NULL)); | |
| 193 | + break; | |
| 194 | + | |
| 195 | + case G_TYPE_UINT: | |
| 196 | + g_value_set_uint(&value, (guint) g_key_file_get_integer(key_file,group_name,name,NULL)); | |
| 197 | + break; | |
| 198 | + | |
| 199 | + default: | |
| 200 | + lib3270_write_trace(v3270_get_session(widget),"%s has an unexpected value type\n",name); | |
| 201 | + g_value_unset(&value); | |
| 202 | + return; | |
| 203 | + | |
| 204 | + } | |
| 205 | + | |
| 206 | + g_object_set_property(G_OBJECT(widget),name,&value); | |
| 207 | + g_value_unset(&value); | |
| 159 | 208 | |
| 160 | 209 | } |
| 161 | 210 | |
| ... | ... | @@ -203,10 +252,33 @@ |
| 203 | 252 | } |
| 204 | 253 | |
| 205 | 254 | /// @brief This function adds the terminal settings from widget to key_file. |
| 206 | - LIB3270_EXPORT gboolean v3270_load_key_file(GtkWidget *widget, GKeyFile *key_file, const gchar *group_name, GError **error) | |
| 255 | + LIB3270_EXPORT gboolean v3270_load_key_file(GtkWidget *widget, GKeyFile *key_file, const gchar *group_name) | |
| 207 | 256 | { |
| 208 | 257 | g_return_val_if_fail(GTK_IS_V3270(widget),FALSE); |
| 209 | 258 | |
| 259 | + size_t ix; | |
| 260 | + | |
| 261 | + v3270 * terminal = GTK_V3270(widget); | |
| 262 | + v3270Class * klass = GTK_V3270_GET_CLASS(widget); | |
| 263 | + | |
| 264 | + g_object_freeze_notify(G_OBJECT(widget)); | |
| 265 | + | |
| 266 | + // Load Toggles | |
| 267 | + for(ix = 0; ix < G_N_ELEMENTS(klass->properties.toggle); ix++) | |
| 268 | + load_by_pspec(widget,klass->properties.toggle[ix],key_file,group_name); | |
| 269 | + | |
| 270 | + // Load V3270 Responses | |
| 271 | + for(ix = 0; ix < G_N_ELEMENTS(terminal->responses); ix++) | |
| 272 | + load_by_pspec(widget,klass->responses[ix],key_file,group_name); | |
| 273 | + | |
| 274 | + // Load V3270 properties | |
| 275 | + for(ix = 0; ix < V3270_SETTING_COUNT; ix++) | |
| 276 | + load_by_pspec(widget,klass->properties.settings[ix],key_file,group_name); | |
| 277 | + | |
| 278 | + // Load V3270 colors | |
| 279 | + v3270_set_colors(widget,g_key_file_get_string(key_file,group_name,"colors",NULL)); | |
| 280 | + | |
| 281 | + g_object_thaw_notify(G_OBJECT(widget)); | |
| 210 | 282 | |
| 211 | - return FALSE; | |
| 283 | + return TRUE; | |
| 212 | 284 | } | ... | ... |
src/testprogram/testprogram.c
| ... | ... | @@ -65,14 +65,22 @@ |
| 65 | 65 | } |
| 66 | 66 | */ |
| 67 | 67 | |
| 68 | + static GKeyFile * get_key_file() | |
| 69 | + { | |
| 70 | + GKeyFile * key_file = g_key_file_new(); | |
| 71 | + g_key_file_load_from_file(key_file,"terminal.conf",G_KEY_FILE_KEEP_COMMENTS,NULL); | |
| 72 | + return key_file; | |
| 73 | + } | |
| 74 | + | |
| 68 | 75 | static void save_settings(GtkWidget *terminal, GtkWidget *window) |
| 69 | 76 | { |
| 70 | 77 | debug("%s: Saving settings for windows %p",__FUNCTION__,window); |
| 71 | 78 | |
| 72 | - GKeyFile * key_file = g_key_file_new(); | |
| 79 | + GKeyFile * key_file = get_key_file(); | |
| 73 | 80 | v3270_to_key_file(terminal,key_file,"terminal"); |
| 74 | 81 | g_key_file_save_to_file(key_file,"terminal.conf",NULL); |
| 75 | 82 | g_key_file_free(key_file); |
| 83 | + | |
| 76 | 84 | } |
| 77 | 85 | |
| 78 | 86 | static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { |
| ... | ... | @@ -99,6 +107,12 @@ |
| 99 | 107 | v3270_set_font_family(terminal,"Lucida Console"); |
| 100 | 108 | #endif // _WIN32 |
| 101 | 109 | |
| 110 | + // Load settings before connecting the signals. | |
| 111 | + debug("%s: Loading settings...",__FUNCTION__); | |
| 112 | + GKeyFile * key_file = get_key_file(); | |
| 113 | + v3270_load_key_file(terminal,key_file,"terminal"); | |
| 114 | + g_key_file_free(key_file); | |
| 115 | + | |
| 102 | 116 | } |
| 103 | 117 | |
| 104 | 118 | // Create trace window | ... | ... |