Commit ba467025363a5c749beb307fc5d1beb564dc9dd3
1 parent
c6d5dc0d
Exists in
master
and in
4 other branches
Implementing action object.
Showing
7 changed files
with
253 additions
and
39 deletions
Show diff stats
src/actions/abstract.c
... | ... | @@ -34,11 +34,15 @@ |
34 | 34 | static void pw3270Action_init(pw3270Action *action); |
35 | 35 | static void pw3270_action_get_property(GObject *object, guint prop_id, GValue *value, GParamSpec *pspec); |
36 | 36 | static void pw3270_action_set_property(GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec); |
37 | + static void pw3270_action_set_state(GAction *action, GVariant *value); | |
38 | + | |
39 | + static void finalize(GObject *object); | |
37 | 40 | |
38 | 41 | static const GVariantType * pw3270_action_get_state_type(GAction *action); |
39 | 42 | static GVariant * pw3270_action_get_state_property(GAction *action); |
40 | - static GVariantType * pw3270_action_get_parameter_type(GAction *action); | |
41 | - | |
43 | + static const GVariantType * pw3270_action_get_parameter_type(GAction *action); | |
44 | + static GVariant * pw3270_action_get_state_hint(GAction *action); | |
45 | + static void pw3270_action_change_state(GAction *action, GVariant *value); | |
42 | 46 | |
43 | 47 | enum { |
44 | 48 | PROP_NONE, |
... | ... | @@ -53,12 +57,12 @@ |
53 | 57 | |
54 | 58 | void pw3270_action_iface_init(GActionInterface *iface) { |
55 | 59 | iface->get_name = pw3270_action_get_name; |
56 | -// iface->get_parameter_type = pw3270_action_get_parameter_type; | |
60 | + iface->get_parameter_type = pw3270_action_get_parameter_type; | |
57 | 61 | iface->get_state_type = pw3270_action_get_state_type; |
58 | -// iface->get_state_hint = pw3270_action_get_state_hint; | |
62 | + iface->get_state_hint = pw3270_action_get_state_hint; | |
59 | 63 | iface->get_enabled = pw3270_action_get_enabled; |
60 | 64 | iface->get_state = pw3270_action_get_state_property; |
61 | -// iface->change_state = pw3270_action_change_state; | |
65 | + iface->change_state = pw3270_action_change_state; | |
62 | 66 | iface->activate = pw3270_action_activate; |
63 | 67 | } |
64 | 68 | |
... | ... | @@ -70,8 +74,9 @@ |
70 | 74 | |
71 | 75 | GObjectClass *object_class = G_OBJECT_CLASS(klass); |
72 | 76 | |
73 | - object_class->set_property = pw3270_action_set_property; | |
74 | - object_class->get_property = pw3270_action_get_property; | |
77 | + object_class->finalize = finalize; | |
78 | + object_class->set_property = pw3270_action_set_property; | |
79 | + object_class->get_property = pw3270_action_get_property; | |
75 | 80 | |
76 | 81 | klass->get_enabled = return_false; |
77 | 82 | |
... | ... | @@ -124,15 +129,38 @@ |
124 | 129 | |
125 | 130 | void pw3270Action_init(pw3270Action *action) { |
126 | 131 | |
127 | - action->name = "unnamed"; | |
132 | + action->name = NULL; | |
128 | 133 | action->window = NULL; |
134 | + action->state = NULL; | |
135 | + | |
136 | + } | |
137 | + | |
138 | + void finalize(GObject *object) { | |
139 | + | |
140 | + pw3270Action * action = PW3270_ACTION(object); | |
141 | + | |
142 | + if(action->name) { | |
143 | + | |
144 | + debug("Finalizing action \"%s\"",action->name); | |
145 | + g_free(action->name); | |
146 | + action->name = NULL; | |
147 | + | |
148 | + } | |
149 | + | |
150 | + if(action->parameter_type) | |
151 | + g_variant_type_free(action->parameter_type); | |
152 | + | |
153 | + G_OBJECT_CLASS(pw3270Action_parent_class)->finalize(object); | |
129 | 154 | |
130 | 155 | } |
131 | 156 | |
157 | + | |
132 | 158 | void pw3270_action_get_property(GObject *object, guint prop_id, GValue *value, GParamSpec *pspec) { |
133 | 159 | |
134 | 160 | GAction *action = G_ACTION(object); |
135 | 161 | |
162 | + debug("%s(%d)",__FUNCTION__,prop_id); | |
163 | + | |
136 | 164 | switch (prop_id) { |
137 | 165 | case PROP_NAME: |
138 | 166 | g_value_set_string(value, pw3270_action_get_name(action)); |
... | ... | @@ -161,22 +189,57 @@ |
161 | 189 | } |
162 | 190 | |
163 | 191 | void pw3270_action_set_property(GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec) { |
192 | + | |
193 | + debug("%s(%d)",__FUNCTION__,prop_id); | |
194 | + | |
195 | + GAction *action = G_ACTION(object); | |
196 | + | |
197 | + switch (prop_id) | |
198 | + { | |
199 | + case PROP_NAME: | |
200 | + pw3270_action_set_name(action, g_value_get_string(value)); | |
201 | + break; | |
202 | + | |
203 | + case PROP_PARAMETER_TYPE: | |
204 | +// action->parameter_type = g_value_dup_boxed (value); | |
205 | + break; | |
206 | + | |
207 | + case PROP_ENABLED: | |
208 | +// action->enabled = g_value_get_boolean (value); | |
209 | + break; | |
210 | + | |
211 | + case PROP_STATE: | |
212 | + pw3270_action_set_state(action, g_value_get_variant(value)); | |
213 | + break; | |
214 | + | |
215 | + default: | |
216 | + g_assert_not_reached (); | |
217 | + } | |
218 | + | |
164 | 219 | } |
165 | 220 | |
166 | 221 | const gchar * pw3270_action_get_name(GAction *action) { |
167 | 222 | return PW3270_ACTION(action)->name; |
168 | 223 | } |
169 | 224 | |
170 | - const GVariantType * pw3270_action_get_state_type(GAction *action) { | |
171 | - return NULL; | |
172 | - } | |
225 | + void pw3270_action_set_name(GAction *object, const gchar *name) { | |
226 | + | |
227 | + pw3270Action * action = PW3270_ACTION(object); | |
228 | + | |
229 | + debug("%s %s -> %s", __FUNCTION__, action->name, name); | |
230 | + | |
231 | + if(action->name) | |
232 | + g_free(action->name); | |
233 | + | |
234 | + if(name) | |
235 | + action->name = g_strdup(name); | |
236 | + else | |
237 | + action->name = NULL; | |
173 | 238 | |
174 | - GVariant * pw3270_action_get_state_property(GAction *action) { | |
175 | - return g_variant_new_int16(0); | |
176 | 239 | } |
177 | 240 | |
178 | - GVariantType * pw3270_action_get_parameter_type(GAction *action) { | |
179 | - return NULL; | |
241 | + GVariant * pw3270_action_get_state_property(GAction *action) { | |
242 | + return PW3270_ACTION(action)->state; | |
180 | 243 | } |
181 | 244 | |
182 | 245 | gboolean pw3270_action_get_enabled(GAction *action) { |
... | ... | @@ -195,3 +258,33 @@ |
195 | 258 | PW3270_ACTION_GET_CLASS(action)->activate(action,window); |
196 | 259 | |
197 | 260 | } |
261 | + | |
262 | + const GVariantType * pw3270_action_get_parameter_type(GAction *action) { | |
263 | + debug("%s",__FUNCTION__); | |
264 | + return NULL; | |
265 | + } | |
266 | + | |
267 | + const GVariantType * pw3270_action_get_state_type(GAction *object) { | |
268 | + | |
269 | + pw3270Action * action = PW3270_ACTION(object); | |
270 | + | |
271 | + if(action->state != NULL) | |
272 | + return g_variant_get_type(action->state); | |
273 | + else | |
274 | + return NULL; | |
275 | + | |
276 | + } | |
277 | + | |
278 | + GVariant * pw3270_action_get_state_hint(GAction *action) { | |
279 | + debug("%s",__FUNCTION__); | |
280 | + return NULL; | |
281 | + } | |
282 | + | |
283 | + void pw3270_action_change_state(GAction *action, GVariant *value) { | |
284 | + debug("%s",__FUNCTION__); | |
285 | + pw3270_action_set_state (action, value); | |
286 | + } | |
287 | + | |
288 | + void pw3270_action_set_state(GAction *action, GVariant *value) { | |
289 | + debug("%s",__FUNCTION__); | |
290 | + } | ... | ... |
src/actions/actions.cbp
src/actions/lib3270.c
... | ... | @@ -47,15 +47,13 @@ |
47 | 47 | typedef struct _Lib3270Action { |
48 | 48 | pw3270Action parent; |
49 | 49 | |
50 | - const LIB3270_ACTION * definition; | |
51 | - | |
50 | + const LIB3270_ACTION * definition; | |
52 | 51 | |
53 | 52 | } Lib3270Action; |
54 | 53 | |
55 | 54 | static void Lib3270Action_class_init(Lib3270ActionClass *klass); |
56 | 55 | static void Lib3270Action_init(Lib3270Action *action); |
57 | 56 | |
58 | - | |
59 | 57 | G_DEFINE_TYPE(Lib3270Action, Lib3270Action, PW3270_TYPE_ACTION); |
60 | 58 | |
61 | 59 | static gboolean action_enabled(GAction *action, GtkWidget *window) { |
... | ... | @@ -84,23 +82,23 @@ |
84 | 82 | action->get_enabled = action_enabled; |
85 | 83 | action->activate = action_activate; |
86 | 84 | |
87 | - | |
88 | 85 | } |
89 | 86 | |
90 | 87 | void Lib3270Action_init(Lib3270Action *action) { |
91 | 88 | } |
92 | 89 | |
93 | - GAction * pw3270_action_get_from_lib3270(const LIB3270_ACTION * definition) { | |
90 | + GAction * pw3270_action_new_from_lib3270(const LIB3270_ACTION * definition, GtkWidget *window) { | |
94 | 91 | |
95 | - Lib3270Action * action = (Lib3270Action *) g_object_new(PW3270_TYPE_LIB3270_ACTION, NULL); | |
96 | - action->definition = definition; | |
92 | + Lib3270Action * action = (Lib3270Action *) g_object_new(PW3270_TYPE_LIB3270_ACTION, NULL); | |
93 | + pw3270Action * abstract = PW3270_ACTION(action); | |
97 | 94 | |
98 | - { | |
99 | - pw3270Action * abstract = PW3270_ACTION(action); | |
95 | + action->definition = definition; | |
96 | + abstract->window = window; | |
100 | 97 | |
101 | - abstract->name = definition->name; | |
98 | + if(abstract->name) | |
99 | + g_free(abstract->name); | |
102 | 100 | |
103 | - } | |
101 | + abstract->name = g_strconcat("win.",definition->name,NULL); | |
104 | 102 | |
105 | 103 | return G_ACTION(action); |
106 | 104 | } | ... | ... |
src/actions/private.h
src/actions/testprogram/testprogram.c
... | ... | @@ -29,10 +29,10 @@ |
29 | 29 | */ |
30 | 30 | |
31 | 31 | #include <config.h> |
32 | - #include <pw3270/actions.h> | |
33 | - #include <pw3270/window.h> | |
34 | - #include <lib3270.h> | |
32 | + #include <v3270.h> | |
33 | + #include <v3270/trace.h> | |
35 | 34 | #include <lib3270/log.h> |
35 | + #include <pw3270/actions.h> | |
36 | 36 | |
37 | 37 | /*---[ Implement ]----------------------------------------------------------------------------------*/ |
38 | 38 | |
... | ... | @@ -44,17 +44,60 @@ |
44 | 44 | return NULL; |
45 | 45 | } |
46 | 46 | |
47 | - int main (int argc, char **argv) { | |
47 | + static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | |
48 | 48 | |
49 | - GAction * action = pw3270_action_get_from_lib3270(lib3270_action_get_by_name("testpattern")); | |
49 | + GtkWidget * window = gtk_application_window_new(app); | |
50 | + GtkWidget * terminal = v3270_new(); | |
51 | + GtkWidget * vBox = gtk_box_new(GTK_ORIENTATION_VERTICAL,2); | |
52 | + GtkWidget * notebook = gtk_notebook_new(); | |
53 | + GtkWidget * toolbar = gtk_toolbar_new(); | |
50 | 54 | |
51 | - g_message("Action name is \"%s\"",g_action_get_name(action)); | |
52 | - g_message("Action is %s",g_action_get_enabled(action) ? "enabled" : "disabled"); | |
55 | + pw3270_window_add_actions(window); | |
53 | 56 | |
54 | - g_object_unref(action); | |
55 | - return 0; | |
57 | + gtk_box_pack_start(GTK_BOX(vBox),toolbar,FALSE,TRUE,0); | |
58 | + gtk_box_pack_start(GTK_BOX(vBox),notebook,TRUE,TRUE,0); | |
56 | 59 | |
57 | - } | |
60 | + // Create Terminal window | |
61 | + { | |
62 | + gtk_widget_set_can_default(terminal,TRUE); | |
63 | + | |
64 | + gtk_notebook_append_page(GTK_NOTEBOOK(notebook),terminal,gtk_label_new("Terminal")); | |
65 | + | |
66 | +#ifdef _WIN32 | |
67 | + v3270_set_font_family(terminal,"Droid Sans Mono"); | |
68 | +#endif // _WIN32 | |
69 | + | |
70 | + } | |
71 | + | |
72 | + // Create trace window | |
73 | + gtk_notebook_append_page(GTK_NOTEBOOK(notebook),v3270_trace_new(terminal),gtk_label_new("Trace")); | |
74 | + | |
75 | + // Setup and show main window | |
76 | + gtk_window_set_position(GTK_WINDOW(window),GTK_WIN_POS_CENTER); | |
77 | + gtk_window_set_default_size (GTK_WINDOW (window), 800, 500); | |
78 | + gtk_container_add(GTK_CONTAINER(window),vBox); | |
79 | + gtk_widget_show_all(window); | |
80 | + | |
81 | + gtk_widget_grab_focus(terminal); | |
82 | + | |
83 | +} | |
84 | + | |
85 | +int main (int argc, char **argv) { | |
86 | + | |
87 | + GtkApplication *app; | |
88 | + int status; | |
89 | + | |
90 | + app = gtk_application_new ("br.com.bb.pw3270",G_APPLICATION_FLAGS_NONE); | |
91 | + | |
92 | + g_signal_connect (app, "activate", G_CALLBACK(activate), NULL); | |
93 | + | |
94 | + status = g_application_run (G_APPLICATION (app), argc, argv); | |
95 | + g_object_unref (app); | |
96 | + | |
97 | + g_message("rc=%d",status); | |
98 | + | |
99 | + return 0; | |
58 | 100 | |
101 | +} | |
59 | 102 | |
60 | 103 | ... | ... |
... | ... | @@ -0,0 +1,69 @@ |
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 - 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 | + /** | |
31 | + * @brief Integrate pw3270 actions with the application window. | |
32 | + * | |
33 | + */ | |
34 | + | |
35 | + #include "private.h" | |
36 | + #include <lib3270/actions.h> | |
37 | + | |
38 | + void pw3270_window_add_actions(GtkWidget * appwindow) { | |
39 | + | |
40 | + GActionMap *map = G_ACTION_MAP(appwindow); | |
41 | + | |
42 | + // g_action_map_add_action(map,pw3270_action_new_from_lib3270(lib3270_action_get_by_name("testpattern"), appwindow)); | |
43 | + | |
44 | + GAction *action = pw3270_action_new_from_lib3270(lib3270_action_get_by_name("testpattern"), appwindow); | |
45 | + | |
46 | + debug("--> \"%s\"",pw3270_action_get_name(action)); | |
47 | + | |
48 | + g_action_map_add_action(map,action); | |
49 | + | |
50 | + debug("--> \"%s\"",pw3270_action_get_name(action)); | |
51 | + | |
52 | + /* | |
53 | + size_t ix; | |
54 | + | |
55 | + // Map lib3270 actions | |
56 | + const LIB3270_ACTION * actions = lib3270_get_actions(); | |
57 | + | |
58 | + for(ix = 0; actions[ix].name; ix++) { | |
59 | + | |
60 | + // g_autofree gchar * name = g_strconcat("win.", actions[ix].name, NULL); | |
61 | + debug("Creating action %s", actions[ix].name); | |
62 | + g_action_map_add_action(map,pw3270_action_new_from_lib3270(&actions[ix],appwindow)); | |
63 | + | |
64 | + } | |
65 | + */ | |
66 | + | |
67 | + | |
68 | + debug("%s ends",__FUNCTION__); | |
69 | + } | ... | ... |
src/include/pw3270/actions.h
... | ... | @@ -54,11 +54,17 @@ |
54 | 54 | |
55 | 55 | GType pw3270Action_get_type(void) G_GNUC_CONST; |
56 | 56 | |
57 | - GAction * pw3270_action_get_from_lib3270(const LIB3270_ACTION * definition); | |
57 | + GAction * pw3270_action_new_from_lib3270(const LIB3270_ACTION * definition, GtkWidget *window); | |
58 | + | |
58 | 59 | const gchar * pw3270_action_get_name(GAction *action); |
60 | + void pw3270_action_set_name(GAction *action, const gchar *name); | |
61 | + | |
59 | 62 | gboolean pw3270_action_get_enabled(GAction *action); |
60 | 63 | void pw3270_action_activate(GAction *action, GVariant *parameter); |
61 | 64 | |
65 | + /// @brief Add lib3270 actions to an application window. | |
66 | + void pw3270_window_add_actions(GtkWidget * appwindow); | |
67 | + | |
62 | 68 | G_END_DECLS |
63 | 69 | |
64 | 70 | #endif // PW3270_ACTIONS_H_INCLUDED | ... | ... |