Commit 0af119d4e3b2ca45bc8e51500cb3b4b9e83652ad
1 parent
38e4ce37
Exists in
master
and in
1 other branch
Saving accelerators to keyfile.
Showing
6 changed files
with
88 additions
and
12 deletions
Show diff stats
src/include/v3270/actions.h
| @@ -59,12 +59,18 @@ | @@ -59,12 +59,18 @@ | ||
| 59 | 59 | ||
| 60 | LIB3270_EXPORT void v3270_accelerator_map_foreach(GtkWidget *widget,void (*call)(const V3270Accelerator * accel, const char *keys, gpointer ptr), gpointer ptr); | 60 | LIB3270_EXPORT void v3270_accelerator_map_foreach(GtkWidget *widget,void (*call)(const V3270Accelerator * accel, const char *keys, gpointer ptr), gpointer ptr); |
| 61 | 61 | ||
| 62 | + LIB3270_EXPORT void v3270_accelerator_map_to_key_file(GtkWidget *widget, GKeyFile *key_file, const gchar *group_name); | ||
| 63 | + | ||
| 62 | LIB3270_EXPORT const V3270Accelerator * v3270_get_accelerator(GtkWidget *widget, guint keyval, GdkModifierType state); | 64 | LIB3270_EXPORT const V3270Accelerator * v3270_get_accelerator(GtkWidget *widget, guint keyval, GdkModifierType state); |
| 63 | LIB3270_EXPORT void v3270_accelerator_activate(const V3270Accelerator * accel, GtkWidget *terminal); | 65 | LIB3270_EXPORT void v3270_accelerator_activate(const V3270Accelerator * accel, GtkWidget *terminal); |
| 64 | LIB3270_EXPORT gboolean v3270_accelerator_compare(const V3270Accelerator * accel, const guint keyval, const GdkModifierType mods); | 66 | LIB3270_EXPORT gboolean v3270_accelerator_compare(const V3270Accelerator * accel, const guint keyval, const GdkModifierType mods); |
| 65 | LIB3270_EXPORT const gchar * v3270_accelerator_get_name(const V3270Accelerator * accel); | 67 | LIB3270_EXPORT const gchar * v3270_accelerator_get_name(const V3270Accelerator * accel); |
| 66 | LIB3270_EXPORT const gchar * v3270_accelerator_get_description(const V3270Accelerator * accel); | 68 | LIB3270_EXPORT const gchar * v3270_accelerator_get_description(const V3270Accelerator * accel); |
| 67 | 69 | ||
| 70 | + /// @brief Converts the accelerator into a string which can be used to represent the accelerator to the user. | ||
| 71 | + /// @return A newly-allocated string representing the accelerator. | ||
| 72 | + LIB3270_EXPORT gchar * v3270_accelerator_get_label(const V3270Accelerator * accel); | ||
| 73 | + | ||
| 68 | G_END_DECLS | 74 | G_END_DECLS |
| 69 | 75 | ||
| 70 | #endif // V3270_ACTIONS_H_INCLUDED | 76 | #endif // V3270_ACTIONS_H_INCLUDED |
src/terminal/keyboard/accelerator.c
| @@ -142,6 +142,8 @@ | @@ -142,6 +142,8 @@ | ||
| 142 | 142 | ||
| 143 | g_autofree gchar * keyname = gtk_accelerator_name(accel->key,accel->mods); | 143 | g_autofree gchar * keyname = gtk_accelerator_name(accel->key,accel->mods); |
| 144 | g_string_append(str,keyname); | 144 | g_string_append(str,keyname); |
| 145 | + | ||
| 146 | + | ||
| 145 | } | 147 | } |
| 146 | 148 | ||
| 147 | accelerator = g_slist_next(accelerator); | 149 | accelerator = g_slist_next(accelerator); |
| @@ -154,3 +156,8 @@ | @@ -154,3 +156,8 @@ | ||
| 154 | g_string_free(str,FALSE); | 156 | g_string_free(str,FALSE); |
| 155 | 157 | ||
| 156 | } | 158 | } |
| 159 | + | ||
| 160 | + LIB3270_EXPORT gchar * v3270_accelerator_get_label(const V3270Accelerator * accel) | ||
| 161 | + { | ||
| 162 | + return gtk_accelerator_get_label(accel->key,accel->mods); | ||
| 163 | + } |
src/terminal/keyboard/init.c
| @@ -96,13 +96,6 @@ | @@ -96,13 +96,6 @@ | ||
| 96 | 96 | ||
| 97 | } | 97 | } |
| 98 | 98 | ||
| 99 | -#ifdef DEBUG | ||
| 100 | - void show_accelerator(const V3270Accelerator * accel, const char *keys, gpointer ptr) | ||
| 101 | - { | ||
| 102 | - debug("%s=%s",v3270_accelerator_get_name(accel),keys); | ||
| 103 | - } | ||
| 104 | -#endif // DEBUG | ||
| 105 | - | ||
| 106 | void v3270_init_accelerators(v3270 *widget) | 99 | void v3270_init_accelerators(v3270 *widget) |
| 107 | { | 100 | { |
| 108 | size_t ix; | 101 | size_t ix; |
| @@ -165,10 +158,6 @@ | @@ -165,10 +158,6 @@ | ||
| 165 | 158 | ||
| 166 | v3270_accelerator_map_sort(widget); | 159 | v3270_accelerator_map_sort(widget); |
| 167 | 160 | ||
| 168 | -#ifdef DEBUG | ||
| 169 | - v3270_accelerator_map_foreach(widget,show_accelerator,NULL); | ||
| 170 | -#endif // DEBUG | ||
| 171 | - | ||
| 172 | } | 161 | } |
| 173 | 162 | ||
| 174 | 163 |
| @@ -0,0 +1,68 @@ | @@ -0,0 +1,68 @@ | ||
| 1 | +/* | ||
| 2 | + * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | ||
| 3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | ||
| 4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | ||
| 5 | + * | ||
| 6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | ||
| 7 | + * | ||
| 8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | ||
| 9 | + * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | ||
| 10 | + * Free Software Foundation. | ||
| 11 | + * | ||
| 12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | ||
| 13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | ||
| 14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | ||
| 15 | + * obter mais detalhes. | ||
| 16 | + * | ||
| 17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | ||
| 18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | ||
| 19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | ||
| 20 | + * | ||
| 21 | + * Este programa está nomeado como properties.c e possui - linhas de código. | ||
| 22 | + * | ||
| 23 | + * Contatos: | ||
| 24 | + * | ||
| 25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | ||
| 26 | + * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | ||
| 27 | + * | ||
| 28 | + */ | ||
| 29 | + | ||
| 30 | + #include <config.h> | ||
| 31 | + #include <gtk/gtk.h> | ||
| 32 | + #include "private.h" | ||
| 33 | + | ||
| 34 | + //#include <v3270/actions.h> | ||
| 35 | + | ||
| 36 | + struct Args | ||
| 37 | + { | ||
| 38 | + GKeyFile * key_file; | ||
| 39 | + const gchar * group_name; | ||
| 40 | + }; | ||
| 41 | + | ||
| 42 | +/*--[ Implement ]------------------------------------------------------------------------------------*/ | ||
| 43 | + | ||
| 44 | + static void save_accelerator(const V3270Accelerator * accel, const char *keys, gpointer ptr) | ||
| 45 | + { | ||
| 46 | + const gchar * key = v3270_accelerator_get_name(accel); | ||
| 47 | + if(!key) | ||
| 48 | + return; | ||
| 49 | + | ||
| 50 | + debug("%s=%s",v3270_accelerator_get_name(accel),keys); | ||
| 51 | + | ||
| 52 | + g_key_file_set_string( | ||
| 53 | + ((struct Args *) ptr)->key_file, | ||
| 54 | + ((struct Args *) ptr)->group_name, | ||
| 55 | + key, | ||
| 56 | + keys | ||
| 57 | + ); | ||
| 58 | + | ||
| 59 | + } | ||
| 60 | + | ||
| 61 | + void v3270_accelerator_map_to_key_file(GtkWidget *widget, GKeyFile *key_file, const gchar *group_name) | ||
| 62 | + { | ||
| 63 | + struct Args args = { key_file, group_name }; | ||
| 64 | + | ||
| 65 | + g_key_file_remove_group(key_file,group_name,NULL); | ||
| 66 | + v3270_accelerator_map_foreach(GTK_WIDGET(widget),save_accelerator,&args); | ||
| 67 | + | ||
| 68 | + } |
src/testprogram/testprogram.c
| @@ -106,14 +106,17 @@ | @@ -106,14 +106,17 @@ | ||
| 106 | debug("%s: Saving settings for windows %p",__FUNCTION__,window); | 106 | debug("%s: Saving settings for windows %p",__FUNCTION__,window); |
| 107 | 107 | ||
| 108 | GKeyFile * key_file = get_key_file(); | 108 | GKeyFile * key_file = get_key_file(); |
| 109 | + | ||
| 109 | v3270_to_key_file(terminal,key_file,"terminal"); | 110 | v3270_to_key_file(terminal,key_file,"terminal"); |
| 111 | + v3270_accelerator_map_to_key_file(terminal, key_file, "accelerators"); | ||
| 112 | + | ||
| 110 | g_key_file_save_to_file(key_file,"terminal.conf",NULL); | 113 | g_key_file_save_to_file(key_file,"terminal.conf",NULL); |
| 111 | g_key_file_free(key_file); | 114 | g_key_file_free(key_file); |
| 112 | 115 | ||
| 113 | 116 | ||
| 114 | } | 117 | } |
| 115 | 118 | ||
| 116 | -#endif // _WIN32 | 119 | +#endif // _WIN32 |
| 117 | 120 | ||
| 118 | 121 | ||
| 119 | static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | 122 | static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { |
v3270.cbp
| @@ -274,6 +274,9 @@ | @@ -274,6 +274,9 @@ | ||
| 274 | <Unit filename="src/terminal/keyboard/init.c"> | 274 | <Unit filename="src/terminal/keyboard/init.c"> |
| 275 | <Option compilerVar="CC" /> | 275 | <Option compilerVar="CC" /> |
| 276 | </Unit> | 276 | </Unit> |
| 277 | + <Unit filename="src/terminal/keyboard/keyfile.c"> | ||
| 278 | + <Option compilerVar="CC" /> | ||
| 279 | + </Unit> | ||
| 277 | <Unit filename="src/terminal/keyboard/private.h" /> | 280 | <Unit filename="src/terminal/keyboard/private.h" /> |
| 278 | <Unit filename="src/terminal/keyfile.c"> | 281 | <Unit filename="src/terminal/keyfile.c"> |
| 279 | <Option compilerVar="CC" /> | 282 | <Option compilerVar="CC" /> |