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 | { | ... | ... |