Commit f03b57f32918e3c352f6e7ce6fd48fe4aee3a578
1 parent
e85f5749
Exists in
master
and in
1 other branch
Adding Page Up/Down keys support.
Showing
2 changed files
with
85 additions
and
15 deletions
Show diff stats
src/include/internals.h
... | ... | @@ -151,6 +151,7 @@ |
151 | 151 | V3270_ACCELERATOR_TYPE_INTERNAL, ///< @brief Accelerator is internal. |
152 | 152 | V3270_ACCELERATOR_TYPE_LIB3270_ACTION, ///< @brief Accelerator is a lib3270 action. |
153 | 153 | V3270_ACCELERATOR_TYPE_LIB3270_TOGGLE, ///< @brief Accelerator is a lib3270 toggle. |
154 | + V3270_ACCELERATOR_TYPE_PFKEY, ///< @brief Accelerator is a PFKey redirector. | |
154 | 155 | V3270_ACCELERATOR_TYPE_CUSTOM, ///< @brief Custom (application based) accelerator. |
155 | 156 | }; |
156 | 157 | |
... | ... | @@ -169,6 +170,13 @@ |
169 | 170 | const gchar *name; |
170 | 171 | } V3270CustomAccelerator; |
171 | 172 | |
173 | + typedef struct _V3270PFKeyAccelerator | |
174 | + { | |
175 | + struct _V3270Accelerator parent; | |
176 | + const gchar *name; | |
177 | + unsigned short keycode; | |
178 | + } V3270PFKeyAccelerator; | |
179 | + | |
172 | 180 | typedef enum v3270_toggleable_dialog |
173 | 181 | { |
174 | 182 | V3270_TOGGLEABLE_DIALOG_PASTE_FAILED, | ... | ... |
src/terminal/keyboard/keyfile.c
... | ... | @@ -30,10 +30,9 @@ |
30 | 30 | #include <config.h> |
31 | 31 | #include <gtk/gtk.h> |
32 | 32 | #include <terminal.h> |
33 | + #include <lib3270/actions.h> | |
33 | 34 | #include "private.h" |
34 | 35 | |
35 | - //#include <v3270/actions.h> | |
36 | - | |
37 | 36 | struct Args |
38 | 37 | { |
39 | 38 | GKeyFile * key_file; |
... | ... | @@ -44,18 +43,37 @@ |
44 | 43 | |
45 | 44 | static void save_accelerator(const V3270Accelerator * accel, const char *keys, gpointer ptr) |
46 | 45 | { |
47 | - const gchar * key = v3270_accelerator_get_name(accel); | |
48 | - if(!key) | |
49 | - return; | |
50 | 46 | |
51 | - debug("%s=%s",v3270_accelerator_get_name(accel),keys); | |
47 | + if(accel->type == V3270_ACCELERATOR_TYPE_PFKEY) | |
48 | + { | |
49 | + // It's a PF-Key action! | |
50 | + g_autofree gchar * key = g_strdup_printf("pf%u",((V3270PFKeyAccelerator *)accel)->keycode); | |
51 | + | |
52 | + debug("%s=%s",((V3270PFKeyAccelerator *)accel)->name,key); | |
52 | 53 | |
53 | - g_key_file_set_string( | |
54 | - ((struct Args *) ptr)->key_file, | |
55 | - ((struct Args *) ptr)->group_name, | |
56 | - key, | |
57 | - (keys ? keys : "") | |
58 | - ); | |
54 | + g_key_file_set_string( | |
55 | + ((struct Args *) ptr)->key_file, | |
56 | + ((struct Args *) ptr)->group_name, | |
57 | + ((V3270PFKeyAccelerator *)accel)->name, | |
58 | + key | |
59 | + ); | |
60 | + | |
61 | + } | |
62 | + else | |
63 | + { | |
64 | + const gchar * key = v3270_accelerator_get_name(accel); | |
65 | + if(!key) | |
66 | + return; | |
67 | + | |
68 | + debug("%s=%s",v3270_accelerator_get_name(accel),keys); | |
69 | + | |
70 | + g_key_file_set_string( | |
71 | + ((struct Args *) ptr)->key_file, | |
72 | + ((struct Args *) ptr)->group_name, | |
73 | + key, | |
74 | + (keys ? keys : "") | |
75 | + ); | |
76 | + } | |
59 | 77 | |
60 | 78 | } |
61 | 79 | |
... | ... | @@ -68,6 +86,11 @@ |
68 | 86 | |
69 | 87 | } |
70 | 88 | |
89 | + static int fire_pfkey_action(GtkWidget *widget, V3270PFKeyAccelerator *accel) | |
90 | + { | |
91 | + return lib3270_pfkey(v3270_get_session(widget),(int) accel->keycode); | |
92 | + } | |
93 | + | |
71 | 94 | void v3270_accelerator_map_set_entry(v3270 *terminal, const gchar *name, const gchar *keys) |
72 | 95 | { |
73 | 96 | V3270Accelerator * accel = NULL; |
... | ... | @@ -103,8 +126,47 @@ |
103 | 126 | |
104 | 127 | if(!accel) |
105 | 128 | { |
106 | - debug("Can't find accelerator \"%s\"",name); | |
107 | - g_warning("Can't find accelerator \"%s\"",name); | |
129 | + // Is a special PFKey action? | |
130 | + | |
131 | + // Page_Down=pf8 | |
132 | + | |
133 | + unsigned int pfkey = 0; | |
134 | + | |
135 | + if(sscanf(keys,"pf%u",&pfkey) == 1) | |
136 | + { | |
137 | + guint key; | |
138 | + GdkModifierType mods; | |
139 | + | |
140 | + debug("Creating special accelerator for PF%u",pfkey); | |
141 | + | |
142 | + gtk_accelerator_parse(name,&key,&mods); | |
143 | + | |
144 | + if(!key) | |
145 | + { | |
146 | + g_warning("Can't parse accelerator %s",name); | |
147 | + return; | |
148 | + } | |
149 | + | |
150 | + // Remap PFKey accelerator | |
151 | + V3270PFKeyAccelerator *pfAccel = g_new0(V3270PFKeyAccelerator,1); | |
152 | + | |
153 | + pfAccel->keycode = (unsigned short) pfkey; | |
154 | + pfAccel->name = g_intern_string(name); | |
155 | + pfAccel->parent.type = V3270_ACCELERATOR_TYPE_PFKEY; | |
156 | + pfAccel->parent.key = key; | |
157 | + pfAccel->parent.mods = mods; | |
158 | + pfAccel->parent.arg = (gconstpointer) pfAccel; | |
159 | + pfAccel->parent.activate = G_CALLBACK(fire_pfkey_action); | |
160 | + | |
161 | + terminal->accelerators = g_slist_prepend(terminal->accelerators,pfAccel); | |
162 | + | |
163 | + } | |
164 | + else | |
165 | + { | |
166 | + debug("Can't find accelerator \"%s\"",name); | |
167 | + g_warning("Can't find accelerator \"%s\"",name); | |
168 | + } | |
169 | + | |
108 | 170 | return; |
109 | 171 | } |
110 | 172 | |
... | ... | @@ -112,7 +174,7 @@ |
112 | 174 | |
113 | 175 | { |
114 | 176 | size_t ix; |
115 | - gchar ** keycodes = g_strsplit(keys,",",-1); | |
177 | + gchar ** keycodes = g_strsplit(keys," ",-1); | |
116 | 178 | |
117 | 179 | for(ix=0;keycodes[ix];ix++) |
118 | 180 | { | ... | ... |