Commit 574dbb76ae37c0c99702c92b42302727cb291e39
1 parent
60dd822f
Exists in
master
and in
4 other branches
Fixing "cut" & "copy" actions.
Showing
3 changed files
with
63 additions
and
83 deletions
Show diff stats
src/objects/actions/clipboard.c
... | ... | @@ -35,17 +35,55 @@ |
35 | 35 | #include "private.h" |
36 | 36 | #include <v3270.h> |
37 | 37 | |
38 | - static void activate_copy(GAction G_GNUC_UNUSED(*action), GVariant G_GNUC_UNUSED(*parameter), GtkWidget *terminal) { | |
38 | + static V3270_COPY_MODE get_copy_mode_from_parameter(GVariant *parameter) { | |
39 | + | |
40 | + static const struct { | |
41 | + const gchar * name; | |
42 | + V3270_COPY_MODE value; | |
43 | + } targets[] = { | |
44 | + { "auto", V3270_COPY_DEFAULT }, | |
45 | + { "system", V3270_COPY_DEFAULT }, | |
46 | + { "default", V3270_COPY_DEFAULT }, | |
47 | + { "system default", V3270_COPY_DEFAULT }, | |
48 | + { "formatted", V3270_COPY_FORMATTED }, | |
49 | + { "text", V3270_COPY_TEXT }, | |
50 | + { "table", V3270_COPY_TABLE }, | |
51 | + { "append", V3270_COPY_APPEND } | |
52 | + | |
53 | + }; | |
54 | + | |
55 | + if(parameter) { | |
56 | + | |
57 | + const gchar * target = g_variant_get_string(parameter,NULL); | |
58 | + | |
59 | + if(target && *target) { | |
60 | + | |
61 | + size_t ix; | |
62 | + for(ix = 0; ix < G_N_ELEMENTS(targets); ix++) { | |
63 | + | |
64 | + if(!g_ascii_strcasecmp(target,targets[ix].name)) | |
65 | + return targets[ix].value; | |
66 | + | |
67 | + } | |
68 | + | |
69 | + } | |
70 | + | |
71 | + } | |
72 | + | |
73 | + return V3270_COPY_DEFAULT; | |
74 | + } | |
75 | + | |
76 | + static void activate_copy(GAction G_GNUC_UNUSED(*action), GVariant *parameter, GtkWidget *terminal) { | |
39 | 77 | |
40 | 78 | debug("%s",__FUNCTION__); |
41 | - v3270_copy_selection(terminal,V3270_SELECT_TEXT,FALSE); | |
79 | + v3270_clipboard_set(terminal,get_copy_mode_from_parameter(parameter),FALSE); | |
42 | 80 | |
43 | 81 | } |
44 | 82 | |
45 | 83 | static void activate_cut(GAction G_GNUC_UNUSED(*action), GVariant G_GNUC_UNUSED(*parameter), GtkWidget *terminal) { |
46 | 84 | |
47 | 85 | debug("%s",__FUNCTION__); |
48 | - v3270_copy_selection(terminal,V3270_SELECT_TEXT,TRUE); | |
86 | + v3270_clipboard_set(terminal,get_copy_mode_from_parameter(parameter),TRUE); | |
49 | 87 | |
50 | 88 | } |
51 | 89 | |
... | ... | @@ -54,47 +92,23 @@ |
54 | 92 | |
55 | 93 | if(!parameter) { |
56 | 94 | debug("%s %p",__FUNCTION__,"NULL"); |
57 | - v3270_paste_from_url(terminal,NULL); | |
95 | + v3270_clipboard_get_from_url(terminal,NULL); | |
58 | 96 | } else { |
59 | 97 | debug("%s \"%s\"",__FUNCTION__,g_variant_get_string(parameter,NULL)); |
60 | - v3270_paste_from_url(terminal,g_variant_get_string(parameter,NULL)); | |
98 | + v3270_clipboard_get_from_url(terminal,g_variant_get_string(parameter,NULL)); | |
61 | 99 | } |
62 | 100 | |
63 | 101 | } |
64 | 102 | |
65 | 103 | GAction * pw3270_copy_action_new(void) { |
66 | 104 | |
67 | - /* | |
68 | - static const LIB3270_ACTION action_descriptor = { | |
69 | - .name = "copy", | |
70 | - .type = LIB3270_ACTION_TYPE_SELECTION, | |
71 | - | |
72 | - .key = "<ctrl>c", | |
73 | - .icon = "edit-copy", | |
74 | - .label = N_( "_Copy" ), | |
75 | - .summary = N_( "Copy selected area to clipboard." ), | |
76 | - .activate = NULL, | |
77 | - | |
78 | - .group = LIB3270_ACTION_GROUP_SELECTION, | |
79 | - .activatable = lib3270_has_selection | |
80 | - | |
81 | - }; | |
82 | - | |
83 | - GAction * action = pw3270_action_new_from_lib3270(&action_descriptor); | |
84 | - | |
85 | - PW3270_ACTION(action)->activate = activate_copy; | |
86 | - | |
87 | - | |
88 | - return action; | |
89 | - | |
90 | - | |
91 | - */ | |
92 | - | |
93 | 105 | pw3270SimpleAction * action = pw3270_simple_action_new(); |
94 | 106 | |
95 | 107 | action->parent.activate = activate_copy; |
108 | + action->parent.types.parameter = G_VARIANT_TYPE_STRING; | |
109 | + | |
96 | 110 | action->group.id = LIB3270_ACTION_GROUP_SELECTION; |
97 | - action->parent.name = "file.transfer"; | |
111 | + action->parent.name = "copy"; | |
98 | 112 | action->icon_name = "edit-copy"; |
99 | 113 | action->label = N_( "_Copy" ); |
100 | 114 | action->tooltip = N_( "Copy selected area to clipboard." ); |
... | ... | @@ -105,34 +119,13 @@ |
105 | 119 | |
106 | 120 | GAction * pw3270_cut_action_new(void) { |
107 | 121 | |
108 | - /* | |
109 | - static const LIB3270_ACTION action_descriptor = { | |
110 | - .name = "cut", | |
111 | - .type = LIB3270_ACTION_TYPE_SELECTION, | |
112 | - | |
113 | - .key = "<ctrl>x", | |
114 | - .icon = "edit-cut", | |
115 | - .label = N_( "_Cut" ), | |
116 | - .summary = N_( "Cut selected area." ), | |
117 | - .activate = NULL, | |
118 | - | |
119 | - .group = LIB3270_ACTION_GROUP_SELECTION, | |
120 | - .activatable = lib3270_has_selection | |
121 | - | |
122 | - }; | |
123 | - | |
124 | - GAction * action = pw3270_action_new_from_lib3270(&action_descriptor); | |
125 | - | |
126 | - PW3270_ACTION(action)->activate = activate_cut; | |
127 | - | |
128 | - return action; | |
129 | - */ | |
130 | - | |
131 | 122 | pw3270SimpleAction * action = pw3270_simple_action_new(); |
132 | 123 | |
133 | 124 | action->parent.activate = activate_cut; |
125 | + action->parent.types.parameter = G_VARIANT_TYPE_STRING; | |
126 | + | |
134 | 127 | action->group.id = LIB3270_ACTION_GROUP_SELECTION; |
135 | - action->parent.name = "file.transfer"; | |
128 | + action->parent.name = "cut"; | |
136 | 129 | action->icon_name = "edit-cut"; |
137 | 130 | action->label = N_( "C_ut" ); |
138 | 131 | action->tooltip = N_( "Cut selected area." ); |
... | ... | @@ -143,29 +136,6 @@ |
143 | 136 | |
144 | 137 | GAction * pw3270_paste_action_new(void) { |
145 | 138 | |
146 | - /* | |
147 | - static const LIB3270_ACTION action_descriptor = { | |
148 | - .name = "paste", | |
149 | - .type = LIB3270_ACTION_TYPE_SELECTION, | |
150 | - | |
151 | - .key = "<ctrl>v", | |
152 | - .icon = "edit-paste", | |
153 | - .label = N_( "_Paste" ), | |
154 | - .summary = N_( "Paste data from clipboard." ), | |
155 | - .activate = NULL, | |
156 | - | |
157 | - .group = LIB3270_ACTION_GROUP_LOCK_STATE, | |
158 | - .activatable = lib3270_is_unlocked | |
159 | - | |
160 | - }; | |
161 | - | |
162 | - pw3270Action * action = PW3270_ACTION(pw3270_action_new_from_lib3270(&action_descriptor)); | |
163 | - | |
164 | - action->types.parameter = G_VARIANT_TYPE_STRING; | |
165 | - action->activate = activate_paste; | |
166 | - | |
167 | - return G_ACTION(action); | |
168 | - */ | |
169 | 139 | |
170 | 140 | pw3270SimpleAction * action = pw3270_simple_action_new(); |
171 | 141 | ... | ... |
src/objects/application/actions/window.c
... | ... | @@ -56,14 +56,14 @@ |
56 | 56 | |
57 | 57 | } |
58 | 58 | |
59 | - void pw3270_application_new_tab_activated(GSimpleAction * action, GVariant *parameter, gpointer application) { | |
59 | + void pw3270_application_new_tab_activated(GSimpleAction G_GNUC_UNUSED(* action), GVariant G_GNUC_UNUSED(*parameter), gpointer application) { | |
60 | 60 | |
61 | 61 | debug("%s",__FUNCTION__); |
62 | 62 | pw3270_terminal_new(GTK_WIDGET(gtk_application_get_active_window(GTK_APPLICATION(application)))); |
63 | 63 | |
64 | 64 | } |
65 | 65 | |
66 | - void pw3270_application_new_window_activated(GSimpleAction * action, GVariant *parameter, gpointer application) { | |
66 | + void pw3270_application_new_window_activated(GSimpleAction G_GNUC_UNUSED(* action), GVariant G_GNUC_UNUSED(*parameter), gpointer application) { | |
67 | 67 | |
68 | 68 | debug("%s",__FUNCTION__); |
69 | 69 | g_application_activate(application); | ... | ... |
ui/application.xml
... | ... | @@ -115,21 +115,31 @@ |
115 | 115 | <item> |
116 | 116 | <attribute name="label" translatable="yes">Copy</attribute> |
117 | 117 | <attribute name="action">win.copy</attribute> |
118 | + <attribute name="target">auto</attribute> | |
119 | + </item> | |
120 | + | |
121 | + <item> | |
122 | + <attribute name="label" translatable="yes">Copy as text</attribute> | |
123 | + <attribute name="action">win.copy</attribute> | |
124 | + <attribute name="target">text</attribute> | |
118 | 125 | </item> |
119 | 126 | |
120 | 127 | <item> |
121 | 128 | <attribute name="label" translatable="yes">Copy as table</attribute> |
122 | - <attribute name="action">win.copy_as_table</attribute> | |
129 | + <attribute name="action">win.copy</attribute> | |
130 | + <attribute name="target">table</attribute> | |
123 | 131 | </item> |
124 | 132 | |
125 | 133 | <item> |
126 | 134 | <attribute name="label" translatable="yes">Append to copy</attribute> |
127 | - <attribute name="action">win.append_to_copy</attribute> | |
135 | + <attribute name="action">win.copy</attribute> | |
136 | + <attribute name="target">append</attribute> | |
128 | 137 | </item> |
129 | 138 | |
130 | 139 | <item> |
131 | 140 | <attribute name="label" translatable="yes">Cut</attribute> |
132 | 141 | <attribute name="action">win.cut</attribute> |
142 | + <attribute name="target">auto</attribute> | |
133 | 143 | </item> |
134 | 144 | |
135 | 145 | <item> | ... | ... |