Commit ffdee95ea07e227d6b13771b780f74a6fa1888ea
1 parent
8f7e5643
Exists in
master
and in
4 other branches
Implementing application dialog action.
Showing
6 changed files
with
235 additions
and
504 deletions
Show diff stats
src/include/pw3270/actions.h
... | ... | @@ -44,142 +44,46 @@ |
44 | 44 | |
45 | 45 | G_BEGIN_DECLS |
46 | 46 | |
47 | - /* | |
48 | 47 | // |
49 | 48 | // Abstract action |
50 | 49 | // |
51 | - #define PW3270_TYPE_ACTION (pw3270Action_get_type()) | |
52 | - #define PW3270_ACTION(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), PW3270_TYPE_ACTION, pw3270Action)) | |
53 | - #define PW3270_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PW3270_TYPE_ACTION, pw3270ActionClass)) | |
50 | + #define PW3270_TYPE_ACTION (PW3270Action_get_type()) | |
51 | + #define PW3270_ACTION(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), PW3270_TYPE_ACTION, PW3270Action)) | |
52 | + #define PW3270_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PW3270_TYPE_ACTION, PW3270ActionClass)) | |
54 | 53 | #define PW3270_IS_ACTION(inst) (G_TYPE_CHECK_INSTANCE_TYPE ((inst), PW3270_TYPE_ACTION)) |
55 | 54 | #define PW3270_IS_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PW3270_TYPE_ACTION)) |
56 | - #define PW3270_ACTION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PW3270_TYPE_ACTION, pw3270ActionClass)) | |
55 | + #define PW3270_ACTION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PW3270_TYPE_ACTION, PW3270ActionClass)) | |
57 | 56 | |
58 | - typedef struct _pw3270Action { | |
57 | + typedef struct _PW3270Action { | |
59 | 58 | |
60 | 59 | GObject parent; |
61 | 60 | |
62 | - const gchar * name; ///> @brief Action name (const string). | |
63 | - GtkWidget * terminal; ///> @brief The active terminal widget. | |
64 | - | |
65 | - struct { | |
66 | - const GVariantType * state; ///> @brief State type type. | |
67 | - const GVariantType * parameter; ///> @brief Parameter type. | |
68 | - } types; | |
61 | + const gchar * name; | |
62 | + const gchar * icon_name; | |
63 | + const gchar * label; | |
64 | + const gchar * tooltip; | |
69 | 65 | |
70 | 66 | /// @brief Activation method. |
71 | - void (*activate)(GAction *action, GVariant *parameter, GtkWidget *terminal); | |
72 | - | |
73 | - /// @brief Get State method. | |
74 | - GVariant * (*get_state_property)(GAction *action, GtkWidget *terminal); | |
67 | + void (*activate)(GAction *action, GVariant *parameter, GtkApplication *application); | |
75 | 68 | |
76 | - /// @brief Get state hint. | |
77 | - GVariant * (*get_state_hint)(GAction *action, GtkWidget *terminal); | |
69 | + } PW3270Action; | |
78 | 70 | |
79 | - } pw3270Action; | |
80 | - | |
81 | - typedef struct _pw3270ActionClass { | |
71 | + typedef struct _PW3270ActionClass { | |
82 | 72 | |
83 | 73 | GObjectClass parent_class; |
84 | 74 | |
75 | + gboolean (*get_enabled)(GAction *action); | |
76 | + | |
85 | 77 | struct { |
86 | 78 | GParamSpec * state; |
87 | 79 | GParamSpec * enabled; |
88 | 80 | } properties; |
89 | 81 | |
90 | - void (*change_widget)(GAction *action, GtkWidget *from, GtkWidget *to); | |
91 | - gboolean (*get_enabled)(GAction *action, GtkWidget *terminal); | |
92 | - | |
93 | - const gchar * (*get_icon_name)(GAction *action); | |
94 | - const gchar * (*get_label)(GAction *action); | |
95 | - const gchar * (*get_tooltip)(GAction *action); | |
96 | - | |
97 | - } pw3270ActionClass; | |
98 | - | |
99 | - GType pw3270Action_get_type(void) G_GNUC_CONST; | |
100 | - | |
101 | - /// @brief New generic action. | |
102 | - GAction * pw3270_action_new(); | |
103 | - | |
104 | - /// @brief Get action name. | |
105 | - const gchar * pw3270_action_get_name(GAction *action); | |
106 | - | |
107 | - /// @brief Set action name. | |
108 | - void pw3270_action_set_name(GAction *action, const gchar *name); | |
109 | - | |
110 | - /// @brief Get the action icon name. | |
111 | - const gchar * pw3270_action_get_icon_name(GAction *action); | |
112 | - | |
113 | - /// @brief Get the action image icon. | |
114 | - GtkImage * pw3270_action_get_image(GAction *action, GtkIconSize icon_size); | |
115 | - | |
116 | - /// @brief Get the action label. | |
117 | - const gchar * pw3270_action_get_label(GAction *action); | |
118 | - | |
119 | - /// @brief Get the action tooltip. | |
120 | - const gchar * pw3270_action_get_tooltip(GAction *action); | |
121 | - | |
122 | - /// @brief Create a button associated with the action. | |
123 | - //GtkWidget * pw3270_action_button_new(GAction *action, const gchar *action_name); | |
124 | - | |
125 | - /// @brief Associate action with the terminal widget. | |
126 | - void pw3270_action_set_terminal_widget(GAction *action, GtkWidget *terminal); | |
127 | - | |
128 | - /// @brief Get lib3270 session handle. | |
129 | - H3270 * pw3270_action_get_session(GAction *action); | |
130 | - */ | |
131 | - | |
132 | - /* | |
133 | - // | |
134 | - // "Simple" action | |
135 | - // | |
136 | - #define PW3270_TYPE_SIMPLE_ACTION (pw3270SimpleAction_get_type()) | |
137 | - #define PW3270_SIMPLE_ACTION(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), PW3270_TYPE_SIMPLE_ACTION, pw3270SimpleAction)) | |
138 | - #define PW3270_SIMPLE_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PW3270_TYPE_SIMPLE_ACTION, pw3270SimpleActionClass)) | |
139 | - #define PW3270_IS_SIMPLE_ACTION(inst) (G_TYPE_CHECK_INSTANCE_TYPE ((inst), PW3270_TYPE_SIMPLE_ACTION)) | |
140 | - #define PW3270_IS_SIMPLE_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PW3270_TYPE_SIMPLE_ACTION)) | |
141 | - #define PW3270_SIMPLE_ACTION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PW3270_TYPE_SIMPLE_ACTION, pw3270SimpleActionClass)) | |
142 | - | |
143 | - typedef struct _pw3270SimpleAction { | |
144 | - | |
145 | - pw3270Action parent; | |
146 | - | |
147 | - // Fixed data | |
148 | - const gchar * icon_name; | |
149 | - const gchar * label; | |
150 | - const gchar * tooltip; | |
151 | - | |
152 | - // Lib3270 Action group | |
153 | - struct { | |
154 | - LIB3270_ACTION_GROUP id; | |
155 | - const void * listener; | |
156 | - } group; | |
157 | - | |
158 | - /// @brief Activation method. | |
159 | - void (*activate)(GAction *action, GVariant *parameter, GtkWidget *terminal); | |
160 | - | |
161 | - } pw3270SimpleAction; | |
162 | - | |
163 | - typedef struct _pw3270SimpleActionClass { | |
164 | - | |
165 | - pw3270ActionClass parent_class; | |
166 | - | |
167 | - } pw3270SimpleActionClass; | |
168 | - | |
169 | - GType pw3270SimpleAction_get_type(void) G_GNUC_CONST; | |
170 | - | |
171 | - /// @brief Create an empty simple action. | |
172 | - pw3270SimpleAction * pw3270_simple_action_new(); | |
173 | - | |
174 | - /// @brief New simple action from LIB3270's control data. | |
175 | - pw3270SimpleAction * pw3270_simple_action_new_from_lib3270(const LIB3270_ACTION * definition, const gchar *name); | |
176 | - | |
177 | - /// @brief New simple action from LIB3270's action name. | |
178 | - pw3270SimpleAction * pw3270_simple_action_new_from_name(const gchar *source_name, const gchar *name); | |
82 | + } PW3270ActionClass; | |
179 | 83 | |
180 | - /// @brief Update simple action from LIB3270's property description. | |
181 | - void pw3270_simple_action_set_lib3270_property(pw3270SimpleAction *action, const LIB3270_PROPERTY * property); | |
182 | - */ | |
84 | + GType PW3270Action_get_type(void) G_GNUC_CONST; | |
85 | + PW3270Action * pw3270action_new(); | |
86 | + PW3270Action * pw3270_dialog_action_new(GtkWidget * (*factory)(PW3270Action *action, GtkApplication *application)); | |
183 | 87 | |
184 | 88 | // |
185 | 89 | // Action view | ... | ... |
src/objects/actions/abstract.c
1 | 1 | /* |
2 | - * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
2 | + * "Software v3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
3 | 3 | * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a |
4 | 4 | * aplicativos mainframe. Registro no INPI sob o nome G3270. |
5 | 5 | * |
... | ... | @@ -28,34 +28,37 @@ |
28 | 28 | */ |
29 | 29 | |
30 | 30 | #include "private.h" |
31 | - #include <v3270.h> | |
32 | - | |
33 | - /* | |
34 | - | |
35 | - static void pw3270_action_iface_init(GActionInterface *iface); | |
36 | - static void pw3270Action_class_init(pw3270ActionClass *klass); | |
37 | - static void pw3270Action_init(pw3270Action *action); | |
38 | - static void get_property(GObject *object, guint prop_id, GValue *value, GParamSpec *pspec); | |
39 | - static void set_property(GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec); | |
40 | - static gboolean get_enabled(GAction *action); | |
41 | - static void activate(GAction *action, GVariant *parameter); | |
42 | - | |
43 | - static void change_widget(GAction *action, GtkWidget *from, GtkWidget *to); | |
44 | - static const gchar *get_null(GAction *action); | |
45 | - | |
46 | - static void finalize(GObject *object); | |
47 | - | |
48 | - static const GVariantType * get_state_type(GAction *action); | |
49 | - static GVariant * get_state_property(GAction *action); | |
50 | - | |
51 | - static GVariant * internal_get_state_property(GAction *action, GtkWidget *terminal); | |
52 | - static gboolean internal_get_enabled(GAction *action, GtkWidget *terminal); | |
53 | - static void internal_activate(GAction *action, GVariant *parameter, GtkWidget *terminal); | |
54 | - static GVariant * internal_get_state_hint(GAction *action, GtkWidget *terminal); | |
55 | - | |
56 | - static const GVariantType * get_parameter_type(GAction *action); | |
57 | - static GVariant * get_state_hint(GAction *action); | |
58 | - static void change_state(GAction *action, GVariant *value); | |
31 | + #include <pw3270/actions.h> | |
32 | + | |
33 | + static void PW3270_action_iface_init(GActionInterface *iface); | |
34 | + static void PW3270Action_class_init(PW3270ActionClass *klass); | |
35 | + static void PW3270Action_init(PW3270Action *action); | |
36 | + | |
37 | + static void get_property(GObject *object, guint prop_id, GValue *value, GParamSpec *pspec); | |
38 | + static void set_property(GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec); | |
39 | + | |
40 | + static const gchar * get_icon_name(GAction *action); | |
41 | + static const gchar * get_label(GAction *action); | |
42 | + static const gchar * get_tooltip(GAction *action); | |
43 | + static const gchar * get_name(GAction *action); | |
44 | + static const GVariantType * get_state_type(GAction *action); | |
45 | + static const GVariantType * get_parameter_type(GAction *object); | |
46 | + | |
47 | + static void finalize(GObject *object); | |
48 | + | |
49 | + static gboolean get_enabled(GAction *action); | |
50 | + static void activate(GAction *action, GVariant *parameter, GtkApplication *application); | |
51 | + static GVariant * get_state(GAction *action); | |
52 | + | |
53 | + static const gchar * iface_get_name(GAction *action); | |
54 | + static const GVariantType * iface_get_parameter_type(GAction *action); | |
55 | + static GVariant * iface_get_state_hint(GAction *action); | |
56 | + static const GVariantType * iface_get_state_type(GAction *action); | |
57 | + static GVariant * iface_get_state(GAction *action); | |
58 | + static gboolean iface_get_enabled(GAction *action); | |
59 | + static GVariant * iface_get_state(GAction *object); | |
60 | + static void iface_change_state(GAction *object, GVariant *value); | |
61 | + static void iface_activate(GAction *object, GVariant *parameter); | |
59 | 62 | |
60 | 63 | enum { |
61 | 64 | PROP_NONE, |
... | ... | @@ -64,40 +67,24 @@ |
64 | 67 | PROP_ENABLED, |
65 | 68 | PROP_STATE_TYPE, |
66 | 69 | PROP_STATE, |
67 | - PROP_TOOLBAR_ICON, | |
68 | 70 | PROP_ICON_NAME, |
69 | 71 | PROP_LABEL, |
70 | 72 | PROP_TOOLTIP |
71 | 73 | }; |
72 | 74 | |
73 | - G_DEFINE_TYPE_WITH_CODE(pw3270Action, pw3270Action, G_TYPE_OBJECT, G_IMPLEMENT_INTERFACE(G_TYPE_ACTION, pw3270_action_iface_init)) | |
74 | - | |
75 | - void pw3270_action_iface_init(GActionInterface *iface) { | |
76 | - iface->get_name = pw3270_action_get_name; | |
77 | - iface->get_parameter_type = get_parameter_type; | |
78 | - iface->get_state_type = get_state_type; | |
79 | - iface->get_state_hint = get_state_hint; | |
80 | - iface->get_enabled = get_enabled; | |
81 | - iface->get_state = get_state_property; | |
82 | - iface->change_state = change_state; | |
83 | - iface->activate = activate; | |
84 | - } | |
75 | + G_DEFINE_TYPE_WITH_CODE(PW3270Action, PW3270Action, G_TYPE_OBJECT, G_IMPLEMENT_INTERFACE(G_TYPE_ACTION, PW3270_action_iface_init)) | |
85 | 76 | |
86 | - void pw3270Action_class_init(pw3270ActionClass *klass) { | |
77 | + void PW3270Action_class_init(PW3270ActionClass *klass) { | |
87 | 78 | |
88 | 79 | GObjectClass *object_class = G_OBJECT_CLASS(klass); |
89 | 80 | |
90 | 81 | debug("%s",__FUNCTION__); |
91 | 82 | |
92 | - klass->change_widget = change_widget; | |
93 | - klass->get_enabled = internal_get_enabled; | |
94 | - klass->get_icon_name = get_null; | |
95 | - klass->get_label = get_null; | |
96 | - klass->get_tooltip = get_null; | |
83 | + klass->get_enabled = get_enabled; | |
97 | 84 | |
98 | 85 | object_class->finalize = finalize; |
99 | - object_class->set_property = set_property; | |
100 | 86 | object_class->get_property = get_property; |
87 | + object_class->set_property = set_property; | |
101 | 88 | |
102 | 89 | // Install properties |
103 | 90 | g_object_class_install_property(object_class, PROP_NAME, |
... | ... | @@ -106,7 +93,7 @@ |
106 | 93 | N_("Action Name"), |
107 | 94 | N_("The name used to invoke the action"), |
108 | 95 | NULL, |
109 | - G_PARAM_STATIC_NAME| G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY | G_PARAM_STATIC_STRINGS)); | |
96 | + G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
110 | 97 | |
111 | 98 | g_object_class_install_property(object_class, PROP_ICON_NAME, |
112 | 99 | g_param_spec_string ( |
... | ... | @@ -114,15 +101,7 @@ |
114 | 101 | N_("Icon Name"), |
115 | 102 | N_("The name of the icon associated with the action"), |
116 | 103 | NULL, |
117 | - G_PARAM_STATIC_NAME| G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
118 | - | |
119 | - g_object_class_install_property(object_class, PROP_TOOLBAR_ICON, | |
120 | - g_param_spec_object ( | |
121 | - "toolbar-icon", | |
122 | - N_("Icon pixbuf"), | |
123 | - N_("A image widget with the action icon"), | |
124 | - GTK_TYPE_IMAGE, | |
125 | - G_PARAM_STATIC_NAME| G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE)); | |
104 | + G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
126 | 105 | |
127 | 106 | g_object_class_install_property(object_class, PROP_LABEL, |
128 | 107 | g_param_spec_string ( |
... | ... | @@ -130,7 +109,7 @@ |
130 | 109 | N_("The action label"), |
131 | 110 | N_("The label for the action"), |
132 | 111 | NULL, |
133 | - G_PARAM_STATIC_NAME| G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
112 | + G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
134 | 113 | |
135 | 114 | g_object_class_install_property(object_class, PROP_TOOLTIP, |
136 | 115 | g_param_spec_string ( |
... | ... | @@ -138,7 +117,7 @@ |
138 | 117 | N_("The action tooltip"), |
139 | 118 | N_("The tooltip for the action"), |
140 | 119 | NULL, |
141 | - G_PARAM_STATIC_NAME| G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
120 | + G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
142 | 121 | |
143 | 122 | g_object_class_install_property (object_class, PROP_PARAMETER_TYPE, |
144 | 123 | g_param_spec_boxed ("parameter-type", |
... | ... | @@ -152,7 +131,7 @@ |
152 | 131 | N_("State Type"), |
153 | 132 | N_("The type of the state kept by the action"), |
154 | 133 | G_TYPE_VARIANT_TYPE, |
155 | - G_PARAM_STATIC_NAME| G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
134 | + G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | |
156 | 135 | |
157 | 136 | // Enabled property |
158 | 137 | klass->properties.enabled = |
... | ... | @@ -161,7 +140,7 @@ |
161 | 140 | N_("Enabled"), |
162 | 141 | N_("If the action can be activated"), |
163 | 142 | TRUE, |
164 | - G_PARAM_STATIC_NAME| G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS | |
143 | + G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS | |
165 | 144 | ); |
166 | 145 | |
167 | 146 | g_object_class_install_property(object_class, PROP_ENABLED, klass->properties.enabled); |
... | ... | @@ -174,34 +153,21 @@ |
174 | 153 | N_("The state the action is in"), |
175 | 154 | G_VARIANT_TYPE_ANY, |
176 | 155 | NULL, |
177 | - G_PARAM_STATIC_NAME| G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READWRITE | G_PARAM_CONSTRUCT | G_PARAM_STATIC_STRINGS | |
156 | + G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_READWRITE | G_PARAM_CONSTRUCT | G_PARAM_STATIC_STRINGS | |
178 | 157 | ); |
179 | 158 | |
180 | 159 | g_object_class_install_property (object_class, PROP_STATE, klass->properties.state); |
181 | 160 | |
182 | 161 | } |
183 | 162 | |
184 | - void pw3270Action_init(pw3270Action *action) { | |
185 | - | |
186 | - action->terminal = NULL; | |
187 | - action->types.parameter = NULL; | |
188 | - | |
189 | - action->activate = internal_activate; | |
190 | - action->get_state_property = internal_get_state_property; | |
191 | - action->get_state_hint = internal_get_state_hint; | |
192 | - | |
163 | + void PW3270Action_init(PW3270Action *action) { | |
164 | + action->activate = activate; | |
193 | 165 | } |
194 | 166 | |
195 | 167 | void finalize(GObject *object) { |
196 | 168 | |
197 | - pw3270Action * action = PW3270_ACTION(object); | |
198 | - | |
199 | - if(action->terminal) { | |
200 | - pw3270_action_set_terminal_widget(G_ACTION(object),NULL); | |
201 | - action->terminal = NULL; | |
202 | - } | |
203 | - | |
204 | - G_OBJECT_CLASS(pw3270Action_parent_class)->finalize(object); | |
169 | + // PW3270Action * action = PW3270_ACTION(object); | |
170 | + G_OBJECT_CLASS(PW3270Action_parent_class)->finalize(object); | |
205 | 171 | |
206 | 172 | } |
207 | 173 | |
... | ... | @@ -209,27 +175,21 @@ |
209 | 175 | |
210 | 176 | GAction *action = G_ACTION(object); |
211 | 177 | |
212 | -// debug("%s(%d)",__FUNCTION__,prop_id); | |
213 | - | |
214 | 178 | switch (prop_id) { |
215 | 179 | case PROP_NAME: |
216 | - g_value_set_string(value, pw3270_action_get_name(action)); | |
180 | + g_value_set_string(value, g_action_get_name(action)); | |
217 | 181 | break; |
218 | 182 | |
219 | 183 | case PROP_ICON_NAME: |
220 | - g_value_set_string(value, pw3270_action_get_icon_name(action)); | |
221 | - break; | |
222 | - | |
223 | - case PROP_TOOLBAR_ICON: | |
224 | - g_value_set_object(value, pw3270_action_get_image(action,GTK_ICON_SIZE_LARGE_TOOLBAR)); | |
184 | + g_value_set_string(value, get_icon_name(action)); | |
225 | 185 | break; |
226 | 186 | |
227 | 187 | case PROP_LABEL: |
228 | - g_value_set_string(value, pw3270_action_get_label(action)); | |
188 | + g_value_set_string(value, get_label(action)); | |
229 | 189 | break; |
230 | 190 | |
231 | 191 | case PROP_TOOLTIP: |
232 | - g_value_set_string(value, pw3270_action_get_tooltip(action)); | |
192 | + g_value_set_string(value, get_tooltip(action)); | |
233 | 193 | break; |
234 | 194 | |
235 | 195 | case PROP_PARAMETER_TYPE: |
... | ... | @@ -245,37 +205,7 @@ |
245 | 205 | break; |
246 | 206 | |
247 | 207 | case PROP_STATE: |
248 | - g_value_take_variant(value, get_state_property(action)); | |
249 | - break; | |
250 | - | |
251 | - default: | |
252 | - g_assert_not_reached (); | |
253 | - } | |
254 | - | |
255 | - } | |
256 | - | |
257 | - void set_property(GObject *object, guint prop_id, const GValue *value, GParamSpec G_GNUC_UNUSED(*pspec)) { | |
258 | - | |
259 | -// debug("%s(%d)",__FUNCTION__,prop_id); | |
260 | - | |
261 | - GAction *action = G_ACTION(object); | |
262 | - | |
263 | - switch (prop_id) | |
264 | - { | |
265 | - case PROP_NAME: | |
266 | - pw3270_action_set_name(action, g_value_get_string(value)); | |
267 | - break; | |
268 | - | |
269 | - case PROP_PARAMETER_TYPE: | |
270 | -// action->parameter_type = g_value_dup_boxed (value); | |
271 | - break; | |
272 | - | |
273 | - case PROP_ENABLED: | |
274 | -// action->enabled = g_value_get_boolean (value); | |
275 | - break; | |
276 | - | |
277 | - case PROP_STATE: | |
278 | -// pw3270_action_set_state(action, g_value_get_variant(value)); | |
208 | + g_value_take_variant(value, get_state(action)); | |
279 | 209 | break; |
280 | 210 | |
281 | 211 | default: |
... | ... | @@ -284,278 +214,148 @@ |
284 | 214 | |
285 | 215 | } |
286 | 216 | |
287 | - const gchar * pw3270_action_get_name(GAction *action) { | |
288 | - return PW3270_ACTION(action)->name; | |
289 | - } | |
290 | - | |
291 | - void pw3270_action_set_name(GAction *action, const gchar *name) { | |
292 | - PW3270_ACTION(action)->name = g_intern_string(name); | |
293 | - } | |
294 | - | |
295 | - GVariant * internal_get_state_hint(GAction G_GNUC_UNUSED(*action), GtkWidget G_GNUC_UNUSED(*terminal)) { | |
296 | - return NULL; | |
297 | - } | |
298 | - | |
299 | - GVariant * internal_get_state_property(GAction *object, GtkWidget G_GNUC_UNUSED(*terminal)) { | |
300 | - | |
301 | - pw3270Action * action = PW3270_ACTION(object); | |
302 | - | |
303 | - if(action->types.state == G_VARIANT_TYPE_BOOLEAN) | |
304 | - return g_variant_new_boolean(FALSE); | |
305 | - | |
306 | - return NULL; | |
307 | - } | |
308 | - | |
309 | - GVariant * get_state_property(GAction *object) { | |
310 | - | |
311 | - pw3270Action * action = PW3270_ACTION(object); | |
312 | - GVariant * state; | |
313 | - | |
314 | - if(action->terminal) | |
315 | - state = action->get_state_property(object,action->terminal); | |
316 | - else | |
317 | - state = internal_get_state_property(object,NULL); | |
318 | - | |
319 | - if(state) | |
320 | - g_variant_ref(state); | |
321 | - | |
322 | - return state; | |
323 | - } | |
324 | - | |
325 | - const GVariantType * get_parameter_type(GAction *action) { | |
326 | - return PW3270_ACTION(action)->types.parameter; | |
327 | - } | |
328 | - | |
329 | - const GVariantType * get_state_type(GAction *object) { | |
330 | - return PW3270_ACTION(object)->types.state; | |
331 | - } | |
332 | - | |
333 | - GVariant * get_state_hint(GAction *object) { | |
334 | - pw3270Action *action = PW3270_ACTION(object); | |
335 | - return action->get_state_hint(object,action->terminal); | |
336 | - } | |
337 | - | |
338 | - void change_state(GAction G_GNUC_UNUSED(*object), GVariant G_GNUC_UNUSED(*value)) { | |
339 | - debug("%s",__FUNCTION__) | |
217 | + void set_property(GObject G_GNUC_UNUSED(*object), guint G_GNUC_UNUSED(prop_id), const GValue G_GNUC_UNUSED(*value), GParamSpec *pspec) { | |
218 | +// g_message("Action %s property %s is read-only",g_action_get_name(G_ACTION(object)),pspec->name); | |
340 | 219 | } |
341 | 220 | |
342 | 221 | static gboolean bg_notify_enabled(GObject *action) { |
343 | - // debug("%s(%s,%s)",__FUNCTION__,g_action_get_name(G_ACTION(action)),(g_action_get_enabled(G_ACTION(action)) ? "enabled" : "disabled")); | |
222 | + debug("%s(%s,%s)",__FUNCTION__,g_action_get_name(G_ACTION(action)),(g_action_get_enabled(G_ACTION(action)) ? "enabled" : "disabled")); | |
344 | 223 | g_object_notify(action, "enabled"); |
345 | 224 | return FALSE; |
346 | 225 | } |
347 | 226 | |
348 | - void pw3270_action_notify_enabled(GAction *action) { | |
349 | - g_idle_add((GSourceFunc) bg_notify_enabled, G_OBJECT(action)); | |
350 | - } | |
351 | - | |
352 | 227 | static gboolean bg_notify_state(GObject *action) { |
353 | 228 | g_object_notify(action, "state"); |
354 | 229 | return FALSE; |
355 | 230 | } |
356 | 231 | |
357 | - void pw3270_action_notify_state(GAction *action) { | |
358 | - g_idle_add((GSourceFunc) bg_notify_state, G_OBJECT(action)); | |
232 | + void pw3270_action_notify_enabled(GAction *action) { | |
233 | + g_idle_add((GSourceFunc) bg_notify_enabled, G_OBJECT(action)); | |
359 | 234 | } |
360 | 235 | |
361 | - static void change_widget(GAction *object, GtkWidget *from, GtkWidget *to) { | |
362 | - | |
363 | - if(from != to) { | |
364 | - | |
365 | - pw3270Action *action = PW3270_ACTION(object); | |
366 | - | |
367 | - action->terminal = to; | |
368 | - | |
369 | - pw3270_action_notify_enabled(object); | |
370 | - | |
371 | - if(action->types.state) | |
372 | - pw3270_action_notify_state(object); | |
373 | - | |
374 | - } | |
375 | - | |
236 | + void pw3270_action_notify_state(GAction *action) { | |
237 | + if(g_action_get_state_type(action)) | |
238 | + g_idle_add((GSourceFunc) bg_notify_state, G_OBJECT(action)); | |
376 | 239 | } |
377 | 240 | |
378 | - void pw3270_action_set_terminal_widget(GAction *object, GtkWidget *widget) { | |
379 | - | |
380 | - g_return_if_fail(PW3270_IS_ACTION(object)); | |
381 | - | |
382 | - if(widget) { | |
383 | - g_return_if_fail(GTK_IS_V3270(widget)); | |
384 | - } | |
385 | - | |
386 | - pw3270Action * action = PW3270_ACTION(object); | |
387 | - | |
388 | - if(action->terminal != widget) { | |
389 | - PW3270_ACTION_GET_CLASS(object)->change_widget(object,action->terminal,widget); | |
390 | - action->terminal = widget; | |
391 | - } | |
392 | - | |
241 | + gboolean get_enabled(GAction G_GNUC_UNUSED(*object)) { | |
242 | + return TRUE; | |
393 | 243 | } |
394 | 244 | |
395 | - gboolean get_enabled(GAction *object) { | |
396 | - | |
397 | - gboolean enabled = FALSE; | |
398 | - | |
399 | - pw3270Action * action = PW3270_ACTION(object); | |
400 | - | |
401 | - if(action && action->terminal) { | |
402 | - enabled = PW3270_ACTION_GET_CLASS(object)->get_enabled(object,action->terminal); | |
403 | -// debug("Action %s is %s",g_action_get_name(object),enabled ? "enabled" : "disabled"); | |
404 | - } | |
405 | - | |
406 | - return enabled; | |
245 | + void activate(GAction *action, GVariant G_GNUC_UNUSED(*parameter), GtkApplication G_GNUC_UNUSED(*application)) { | |
246 | + g_message("Action %s can't be activated",g_action_get_name(action)); | |
247 | + } | |
407 | 248 | |
249 | + // | |
250 | + // Action methods. | |
251 | + // | |
252 | + GAction * pw3270_action_new() { | |
253 | + return G_ACTION(g_object_new(PW3270_TYPE_ACTION, NULL)); | |
408 | 254 | } |
409 | 255 | |
410 | - void activate(GAction *object, GVariant *parameter) { | |
256 | + GdkPixbuf * pw3270_action_get_pixbuf(GAction *action, GtkIconSize icon_size, GtkIconLookupFlags flags) { | |
411 | 257 | |
412 | - pw3270Action * action = PW3270_ACTION(object); | |
258 | + const gchar * icon_name = v3270_action_get_icon_name(action); | |
413 | 259 | |
414 | - debug("%s: terminal=%p",__FUNCTION__,action->terminal); | |
260 | + if(!icon_name) | |
261 | + return NULL; | |
415 | 262 | |
416 | - if(action && action->terminal) { | |
417 | - action->activate(object,parameter,action->terminal); | |
418 | - } | |
263 | + return gtk_icon_theme_load_icon( | |
264 | + gtk_icon_theme_get_default(), | |
265 | + icon_name, | |
266 | + icon_size, | |
267 | + flags, | |
268 | + NULL | |
269 | + ); | |
419 | 270 | |
420 | 271 | } |
421 | 272 | |
422 | - gboolean internal_get_enabled(GAction G_GNUC_UNUSED(*object), GtkWidget *terminal) { | |
423 | - return terminal != NULL; | |
273 | +// | |
274 | +// Default methods. | |
275 | +// | |
276 | + GVariant * get_state(GAction G_GNUC_UNUSED(*object)) { | |
277 | + return g_variant_new_boolean(TRUE); | |
424 | 278 | } |
425 | 279 | |
426 | - void internal_activate(GAction *action, GVariant G_GNUC_UNUSED(*parameter), GtkWidget G_GNUC_UNUSED(*terminal)) { | |
427 | - debug("%s",__FUNCTION__); | |
428 | - g_message("Action %s can't be activated",pw3270_action_get_name(action)); | |
280 | +// | |
281 | +// Interface Methods. | |
282 | +// | |
283 | + void PW3270_action_iface_init(GActionInterface *iface) { | |
284 | + iface->get_name = iface_get_name; | |
285 | + iface->get_parameter_type = iface_get_parameter_type; | |
286 | + iface->get_state_type = iface_get_state_type; | |
287 | + iface->get_state_hint = iface_get_state_hint; | |
288 | + iface->get_enabled = iface_get_enabled; | |
289 | + iface->get_state = iface_get_state; | |
290 | + iface->change_state = iface_change_state; | |
291 | + iface->activate = iface_activate; | |
429 | 292 | } |
430 | 293 | |
431 | - const gchar * get_null(GAction G_GNUC_UNUSED(*action)) { | |
432 | - return NULL; | |
294 | + const gchar * iface_get_name(GAction *action) { | |
295 | + return get_name(action); | |
433 | 296 | } |
434 | 297 | |
435 | - const gchar * pw3270_action_get_icon_name(GAction *action) { | |
436 | - return PW3270_ACTION_GET_CLASS(action)->get_icon_name(action); | |
437 | - } | |
298 | + GVariant * iface_get_state(GAction *object) { | |
438 | 299 | |
439 | - GtkImage * pw3270_action_get_image(GAction *action, GtkIconSize icon_size) { | |
300 | + GVariant * state = NULL; | |
440 | 301 | |
441 | - const gchar * icon_name = pw3270_action_get_icon_name(action); | |
442 | - if(!icon_name) | |
443 | - return NULL; | |
302 | + if(g_action_get_state_type(object)) { | |
444 | 303 | |
445 | - return GTK_IMAGE(gtk_image_new_from_icon_name(icon_name,icon_size)); | |
446 | - } | |
304 | + state = get_state(object); | |
447 | 305 | |
306 | + if(state) | |
307 | + g_variant_ref(state); | |
448 | 308 | |
449 | - const gchar * pw3270_action_get_label(GAction *action) { | |
450 | - const gchar * label = PW3270_ACTION_GET_CLASS(action)->get_label(action); | |
309 | + } | |
451 | 310 | |
452 | - if(label) | |
453 | - return gettext(label); | |
311 | + return state; | |
454 | 312 | |
455 | - return NULL; | |
456 | 313 | } |
457 | 314 | |
458 | - const gchar * pw3270_action_get_tooltip(GAction *action) { | |
459 | - const gchar * tooltip = PW3270_ACTION_GET_CLASS(action)->get_tooltip(action); | |
315 | + const GVariantType * iface_get_parameter_type(GAction *object) { | |
316 | + return get_parameter_type(object); | |
317 | + } | |
460 | 318 | |
461 | - if(tooltip) | |
462 | - return gettext(tooltip); | |
319 | + const GVariantType * iface_get_state_type(GAction *object) { | |
320 | + return get_state_type(object); | |
321 | + } | |
463 | 322 | |
323 | + GVariant * iface_get_state_hint(GAction G_GNUC_UNUSED(*object)) { | |
464 | 324 | return NULL; |
465 | 325 | } |
466 | 326 | |
467 | - H3270 * pw3270_action_get_session(GAction *action) { | |
468 | - return v3270_get_session(PW3270_ACTION(action)->terminal); | |
327 | + void iface_change_state(GAction G_GNUC_UNUSED(*object), GVariant G_GNUC_UNUSED(*value)) { | |
328 | + debug("%s",__FUNCTION__); | |
469 | 329 | } |
470 | 330 | |
471 | - GAction * pw3270_action_new() { | |
472 | - return G_ACTION(g_object_new(PW3270_TYPE_ACTION, NULL)); | |
331 | + gboolean iface_get_enabled(GAction *object) { | |
332 | + return PW3270_ACTION_GET_CLASS(object)->get_enabled(object); | |
473 | 333 | } |
474 | 334 | |
475 | - gchar * g_action_get_text(GAction *action, const gchar * property_name) { | |
476 | - gchar *rc = NULL; | |
477 | - | |
478 | - GValue value = G_VALUE_INIT; | |
479 | - g_value_init(&value, G_TYPE_STRING); | |
480 | - g_object_get_property(G_OBJECT(action),property_name,&value); | |
481 | - | |
482 | - const gchar * text = g_value_get_string(&value); | |
483 | - if(text) | |
484 | - rc = g_strdup(text); | |
485 | - | |
486 | - g_value_unset(&value); | |
487 | - | |
488 | - return rc; | |
489 | - | |
335 | + void iface_activate(GAction *object, GVariant *parameter) { | |
336 | + PW3270_ACTION(object)->activate(object,parameter,GTK_APPLICATION(g_application_get_default())); | |
490 | 337 | } |
491 | 338 | |
492 | - gchar * g_action_get_tooltip(GAction *action) { | |
493 | - return g_action_get_text(action, "tooltip"); | |
339 | + const gchar * get_icon_name(GAction *action) { | |
340 | + return PW3270_ACTION(action)->icon_name; | |
494 | 341 | } |
495 | 342 | |
496 | - gchar * g_action_get_label(GAction *action) { | |
497 | - return g_action_get_text(action, "label"); | |
343 | + const gchar * get_label(GAction *action) { | |
344 | + return PW3270_ACTION(action)->label; | |
498 | 345 | } |
499 | 346 | |
500 | - gchar * g_action_get_icon_name(GAction *action) { | |
501 | - return g_action_get_text(action, "icon-name"); | |
347 | + const gchar * get_tooltip(GAction *action) { | |
348 | + return PW3270_ACTION(action)->tooltip; | |
502 | 349 | } |
503 | 350 | |
504 | - static GdkPixbuf * pixbuf_from_icon_name(GValue *value, gint width, gint G_GNUC_UNUSED(height), GtkIconLookupFlags flags) { | |
505 | - | |
506 | - const gchar * icon_name = g_value_get_string(value); | |
507 | - | |
508 | - if(!icon_name) | |
509 | - return NULL; | |
510 | - | |
511 | - return gtk_icon_theme_load_icon( | |
512 | - gtk_icon_theme_get_default(), | |
513 | - icon_name, | |
514 | - width, | |
515 | - flags, // GTK_ICON_LOOKUP_GENERIC_FALLBACK, | |
516 | - NULL | |
517 | - ); | |
518 | - | |
351 | + const gchar * get_name(GAction *action) { | |
352 | + return PW3270_ACTION(action)->name; | |
519 | 353 | } |
520 | 354 | |
521 | - GdkPixbuf * g_action_get_pixbuf(GAction *action, GtkIconSize icon_size, GtkIconLookupFlags flags) { | |
522 | - | |
523 | - struct Properties { | |
524 | - const gchar * name; | |
525 | - GType value_type; | |
526 | - GdkPixbuf * (*translate)(GValue *value, gint width, gint height, GtkIconLookupFlags flags); | |
527 | - } properties[] = { | |
528 | - { | |
529 | - .name = "icon-name", | |
530 | - .value_type = G_TYPE_STRING, | |
531 | - .translate = pixbuf_from_icon_name | |
532 | - } | |
533 | - }; | |
534 | - | |
535 | - size_t ix; | |
536 | - GdkPixbuf * pixbuf = NULL; | |
537 | - gint width, height; | |
538 | - | |
539 | - gtk_icon_size_lookup(icon_size,&width,&height); | |
540 | - | |
541 | - for(ix = 0; ix < G_N_ELEMENTS(properties) && !pixbuf; ix++) { | |
542 | - | |
543 | - GParamSpec *spec = g_object_class_find_property(G_OBJECT_GET_CLASS(action),properties[ix].name); | |
544 | - if(spec && spec->value_type == properties[ix].value_type && (spec->flags & G_PARAM_READABLE) != 0) { | |
545 | - | |
546 | - GValue value = G_VALUE_INIT; | |
547 | - g_value_init(&value, properties[ix].value_type); | |
548 | - | |
549 | - g_object_get_property(G_OBJECT(action),properties[ix].name,&value); | |
550 | - | |
551 | - pixbuf = properties[ix].translate(&value,width,height,flags); | |
552 | - | |
553 | - g_value_unset(&value); | |
554 | - | |
555 | - } | |
556 | - | |
557 | - } | |
355 | + const GVariantType * get_state_type(GAction G_GNUC_UNUSED(*object)) { | |
356 | + return NULL; | |
357 | + } | |
558 | 358 | |
559 | - return pixbuf; | |
359 | + const GVariantType * get_parameter_type(GAction G_GNUC_UNUSED(*object)) { | |
360 | + return NULL; | |
560 | 361 | } |
561 | -*/ | ... | ... |
src/objects/actions/dialog.c
... | ... | @@ -32,95 +32,100 @@ |
32 | 32 | * |
33 | 33 | */ |
34 | 34 | |
35 | - /* | |
36 | 35 | #include "private.h" |
37 | - #include <v3270.h> | |
38 | - #include <v3270/settings.h> | |
36 | + #include <pw3270/actions.h> | |
39 | 37 | |
40 | - static void pw3270DialogAction_class_init(pw3270DialogActionClass *klass); | |
41 | - static void pw3270DialogAction_init(pw3270DialogAction *action); | |
42 | - static void activate(GAction G_GNUC_UNUSED(*action), GVariant G_GNUC_UNUSED(*parameter), GtkWidget *terminal); | |
38 | + typedef struct _PW3270DialogAction { | |
43 | 39 | |
44 | - struct _pw3270DialogAction { | |
45 | - | |
46 | - pw3270SimpleAction parent; | |
40 | + PW3270Action parent; | |
47 | 41 | |
48 | 42 | GtkWidget * dialog; |
49 | - GtkWidget * (*factory)(pw3270SimpleAction *, GtkWidget *); | |
50 | - | |
51 | - }; | |
43 | + GtkWidget * (*factory)(PW3270Action *, GtkApplication *); | |
52 | 44 | |
53 | - struct _pw3270DialogActionClass { | |
45 | + } PW3270DialogAction; | |
54 | 46 | |
55 | - pw3270SimpleActionClass parent_class; | |
47 | + typedef struct _PW3270DialogActionClass { | |
56 | 48 | |
57 | - }; | |
49 | + PW3270ActionClass parent_class; | |
58 | 50 | |
59 | - G_DEFINE_TYPE(pw3270DialogAction, pw3270DialogAction, PW3270_TYPE_SIMPLE_ACTION); | |
51 | + } PW3270DialogActionClass; | |
60 | 52 | |
61 | - static gboolean get_enabled(GAction *action, GtkWidget *terminal) { | |
62 | - | |
63 | - if((PW3270_DIALOG_ACTION(action)->dialog)) { | |
64 | - return FALSE; | |
65 | - } | |
53 | + #define PW3270_TYPE_DIALOG_ACTION (PW3270DialogAction_get_type()) | |
54 | + #define PW3270_DIALOG_ACTION(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), PW3270_TYPE_DIALOG_ACTION, PW3270DialogAction)) | |
55 | + #define PW3270_DIALOG_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PW3270_TYPE_DIALOG_ACTION, PW3270DialogActionClass)) | |
56 | + #define PW3270_IS_DIALOG_ACTION(inst) (G_TYPE_CHECK_INSTANCE_TYPE ((inst), PW3270_TYPE_DIALOG_ACTION)) | |
57 | + #define PW3270_IS_DIALOG_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PW3270_TYPE_DIALOG_ACTION)) | |
58 | + #define PW3270_DIALOG_ACTION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PW3270_TYPE_DIALOG_ACTION, PW3270DialogActionClass)) | |
66 | 59 | |
67 | - if(terminal) { | |
68 | - return lib3270_action_group_get_activatable(v3270_get_session(terminal),PW3270_SIMPLE_ACTION(action)->group.id); | |
69 | - } | |
60 | + static void PW3270DialogAction_class_init(PW3270DialogActionClass *klass); | |
61 | + static void PW3270DialogAction_init(PW3270DialogAction *action); | |
62 | + static void activate(GAction *action, GVariant *parameter, GtkApplication *application); | |
63 | + static GtkWidget * factory(PW3270Action *action, GtkApplication *application); | |
64 | + static gboolean get_enabled(GAction *action); | |
70 | 65 | |
71 | - return FALSE; | |
66 | + G_DEFINE_TYPE(PW3270DialogAction, PW3270DialogAction, PW3270_TYPE_ACTION); | |
72 | 67 | |
68 | + PW3270Action * pw3270_dialog_action_new(GtkWidget * (*factory)(PW3270Action *, GtkApplication *application)) { | |
69 | + PW3270DialogAction *action = PW3270_DIALOG_ACTION(g_object_new(PW3270_TYPE_DIALOG_ACTION, NULL)); | |
70 | + action->parent.activate = activate; | |
71 | + action->factory = factory; | |
72 | + return PW3270_ACTION(action); | |
73 | 73 | } |
74 | 74 | |
75 | - static void pw3270DialogAction_class_init(pw3270DialogActionClass *klass) { | |
76 | - klass->parent_class.parent_class.get_enabled = get_enabled; | |
75 | + void PW3270DialogAction_class_init(PW3270DialogActionClass *klass) { | |
76 | + klass->parent_class.get_enabled = get_enabled; | |
77 | 77 | } |
78 | 78 | |
79 | - static void pw3270DialogAction_init(pw3270DialogAction *action) { | |
80 | - | |
81 | - action->dialog = NULL; | |
82 | - action->parent.parent.activate = activate; | |
79 | + void PW3270DialogAction_init(PW3270DialogAction *action) { | |
80 | + action->factory = factory; | |
81 | + } | |
83 | 82 | |
83 | + GtkWidget * factory(PW3270Action *action, GtkApplication G_GNUC_UNUSED(*application)) { | |
84 | + g_warning("No widget factory for action \"%s\"",g_action_get_name(G_ACTION(action))); | |
85 | + return NULL; | |
84 | 86 | } |
85 | 87 | |
86 | - pw3270SimpleAction * pw3270_dialog_action_new(GtkWidget * (*factory)(pw3270SimpleAction *, GtkWidget *)) { | |
88 | + gboolean get_enabled(GAction *action) { | |
87 | 89 | |
88 | - pw3270DialogAction * action = (pw3270DialogAction *) g_object_new(PW3270_TYPE_DIALOG_ACTION, NULL); | |
89 | - action->factory = factory; | |
90 | - return PW3270_SIMPLE_ACTION(action); | |
90 | + if((PW3270_DIALOG_ACTION(action)->dialog)) { | |
91 | + return FALSE; | |
92 | + } | |
93 | + | |
94 | + return PW3270_ACTION_CLASS(PW3270DialogAction_parent_class)->get_enabled(action); | |
91 | 95 | |
92 | 96 | } |
93 | 97 | |
94 | - static void on_destroy(GtkWidget *dialog, pw3270DialogAction *action) { | |
98 | +static void on_destroy(GtkWidget *dialog, PW3270DialogAction *action) { | |
95 | 99 | |
96 | - if(action->dialog == dialog) { | |
100 | + if(action->dialog == dialog) { | |
97 | 101 | action->dialog = NULL; |
98 | 102 | pw3270_action_notify_enabled(G_ACTION(action)); |
99 | - } | |
103 | + } | |
100 | 104 | |
101 | 105 | } |
102 | 106 | |
103 | - void activate(GAction *object, GVariant G_GNUC_UNUSED(*parameter), GtkWidget *terminal) { | |
104 | - | |
105 | - if(!GTK_IS_V3270(terminal)) | |
106 | - return; | |
107 | + void activate(GAction *object, GVariant G_GNUC_UNUSED(*parameter), GtkApplication *application) { | |
107 | 108 | |
108 | - pw3270DialogAction * action = PW3270_DIALOG_ACTION(object); | |
109 | + PW3270DialogAction * action = PW3270_DIALOG_ACTION(object); | |
109 | 110 | |
110 | - if(action->dialog || !action->factory) | |
111 | + if(action->dialog) | |
111 | 112 | return; |
112 | 113 | |
113 | - action->dialog = action->factory((pw3270SimpleAction *) object, terminal); | |
114 | - pw3270_action_notify_enabled(G_ACTION(action)); | |
114 | + action->dialog = action->factory(PW3270_ACTION(action), application); | |
115 | 115 | |
116 | 116 | if(action->dialog) { |
117 | 117 | |
118 | + GtkWindow * window = gtk_application_get_active_window(application); | |
119 | + if(window) { | |
120 | + gtk_window_set_attached_to(GTK_WINDOW(action->dialog), GTK_WIDGET(window)); | |
121 | + gtk_window_set_transient_for(GTK_WINDOW(action->dialog),window); | |
122 | + } | |
123 | + | |
124 | + pw3270_action_notify_enabled(G_ACTION(action)); | |
118 | 125 | g_signal_connect(action->dialog,"destroy",G_CALLBACK(on_destroy),action); |
119 | 126 | g_signal_connect(action->dialog,"close",G_CALLBACK(gtk_widget_destroy),NULL); |
120 | - gtk_widget_show_all(GTK_WIDGET(action->dialog)); | |
127 | + gtk_widget_show(GTK_WIDGET(action->dialog)); | |
121 | 128 | |
122 | 129 | } |
123 | 130 | |
124 | 131 | } |
125 | - | |
126 | -*/ | ... | ... |
src/objects/application/actions/about.c
... | ... | @@ -28,9 +28,10 @@ |
28 | 28 | */ |
29 | 29 | |
30 | 30 | #include "../private.h" |
31 | + #include <pw3270/actions.h> | |
31 | 32 | #include <pw3270/application.h> |
32 | 33 | |
33 | - void pw3270_application_about_activated(GSimpleAction G_GNUC_UNUSED(* action), GVariant G_GNUC_UNUSED(*parameter), gpointer application) { | |
34 | + static GtkWidget * factory(PW3270Action G_GNUC_UNUSED(*action), GtkApplication G_GNUC_UNUSED(*application)) { | |
34 | 35 | |
35 | 36 | static const gchar *authors[] = |
36 | 37 | { |
... | ... | @@ -119,10 +120,22 @@ |
119 | 120 | gtk_about_dialog_set_authors(dialog,authors); |
120 | 121 | gtk_about_dialog_set_translator_credits(dialog,_("translator-credits")); |
121 | 122 | |
122 | - g_signal_connect(dialog,"close",G_CALLBACK(gtk_widget_destroy),NULL); | |
123 | + gtk_window_set_modal(GTK_WINDOW(dialog),TRUE); | |
124 | + | |
123 | 125 | g_signal_connect(dialog,"response",G_CALLBACK(gtk_widget_destroy),NULL); |
124 | 126 | gtk_widget_show_all(GTK_WIDGET(dialog)); |
125 | 127 | |
128 | + return GTK_WIDGET(dialog); | |
126 | 129 | |
127 | 130 | } |
128 | 131 | |
132 | + GAction * pw3270_about_action_new() { | |
133 | + | |
134 | + PW3270Action * action = pw3270_dialog_action_new(factory); | |
135 | + | |
136 | + action->name = "about"; | |
137 | + action->label = _("About pw3270"); | |
138 | + action->icon_name = "help-about"; | |
139 | + | |
140 | + return G_ACTION(action); | |
141 | + } | ... | ... |
src/objects/application/application.c
... | ... | @@ -321,16 +321,15 @@ |
321 | 321 | |
322 | 322 | void startup(GApplication *application) { |
323 | 323 | |
324 | + size_t ix; | |
325 | + | |
324 | 326 | G_APPLICATION_CLASS(pw3270Application_parent_class)->startup(application); |
325 | 327 | |
328 | + /* | |
326 | 329 | // |
327 | 330 | // Setup application default actions. |
328 | 331 | // |
329 | 332 | static GActionEntry actions[] = { |
330 | - { | |
331 | - .name = "about", | |
332 | - .activate = pw3270_application_about_activated, | |
333 | - }, | |
334 | 333 | |
335 | 334 | { |
336 | 335 | .name = "preferences", |
... | ... | @@ -375,6 +374,15 @@ |
375 | 374 | G_N_ELEMENTS(actions), |
376 | 375 | application |
377 | 376 | ); |
377 | + */ | |
378 | + | |
379 | + GAction * actions[] = { | |
380 | + pw3270_about_action_new() | |
381 | + }; | |
382 | + | |
383 | + for(ix = 0; ix < G_N_ELEMENTS(actions); ix++) { | |
384 | + g_action_map_add_action(G_ACTION_MAP(application),actions[ix]); | |
385 | + } | |
378 | 386 | |
379 | 387 | // |
380 | 388 | // Setup application menus | ... | ... |
src/objects/application/private.h
... | ... | @@ -50,11 +50,12 @@ |
50 | 50 | G_GNUC_INTERNAL GtkWidget * pw3270_terminal_new(const gchar *session_file); |
51 | 51 | |
52 | 52 | // Actions |
53 | + G_GNUC_INTERNAL GAction * pw3270_about_action_new(); | |
54 | + | |
53 | 55 | G_GNUC_INTERNAL void pw3270_application_generic_activated(GSimpleAction * action, GVariant *parameter, gpointer application); |
54 | 56 | G_GNUC_INTERNAL void pw3270_application_quit_activated(GSimpleAction * action, GVariant *parameter, gpointer application); |
55 | 57 | G_GNUC_INTERNAL void pw3270_application_new_tab_activated(GSimpleAction * action, GVariant *parameter, gpointer application); |
56 | 58 | G_GNUC_INTERNAL void pw3270_application_new_window_activated(GSimpleAction * action, GVariant *parameter, gpointer application); |
57 | - G_GNUC_INTERNAL void pw3270_application_about_activated(GSimpleAction * action, GVariant *parameter, gpointer application); | |
58 | 59 | G_GNUC_INTERNAL void pw3270_application_preferences_activated(GSimpleAction * action, GVariant *parameter, gpointer application); |
59 | 60 | |
60 | 61 | G_GNUC_INTERNAL void pw3270_application_open_activated(GSimpleAction * action, GVariant *parameter, gpointer application); | ... | ... |