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); | ... | ... |