mirror of
https://gitlab.gnome.org/GNOME/glade.git
synced 2025-11-27 00:06:20 -05:00
Implemented GladeSignalEditor::callback-suggestions signal
(based on patch by Marco Diego Aurélio Mesquita <marcodiegomesquita@gmail.com >) Closes bug #667570 "Implement callback name suggestion on glade-signal-editor" Added GladeSignalEditor:widget missing property Added new accumulator _glade_strv_handled_accumulator() Added new marshall BOXED:OBJECT
This commit is contained in:
parent
51d10c3202
commit
0e0bf998f2
@ -88,6 +88,19 @@ _glade_string_accumulator (GSignalInvocationHint * ihint,
|
||||
return (handler_str == NULL);
|
||||
}
|
||||
|
||||
gboolean
|
||||
_glade_strv_handled_accumulator (GSignalInvocationHint *ihint,
|
||||
GValue *return_accu,
|
||||
const GValue *handler_return, gpointer dummy)
|
||||
{
|
||||
const gchar **handler_strv;
|
||||
|
||||
handler_strv = g_value_get_boxed (handler_return);
|
||||
g_value_set_boxed (return_accu, handler_strv);
|
||||
|
||||
return (handler_strv == NULL);
|
||||
}
|
||||
|
||||
gboolean
|
||||
_glade_stop_emission_accumulator (GSignalInvocationHint *ihint,
|
||||
GValue *return_accu,
|
||||
|
||||
@ -25,6 +25,11 @@ gboolean _glade_string_accumulator (GSignalInvocationHint *ihint,
|
||||
const GValue *handler_return,
|
||||
gpointer dummy);
|
||||
|
||||
gboolean _glade_strv_handled_accumulator (GSignalInvocationHint *ihint,
|
||||
GValue *return_accu,
|
||||
const GValue *handler_return,
|
||||
gpointer dummy);
|
||||
|
||||
gboolean _glade_stop_emission_accumulator (GSignalInvocationHint *ihint,
|
||||
GValue *return_accu,
|
||||
const GValue *handler_return,
|
||||
|
||||
@ -22,3 +22,4 @@ BOOLEAN:STRING,STRING,STRING,BOXED
|
||||
BOOLEAN:STRING,BOXED,OBJECT
|
||||
STRING:OBJECT
|
||||
INT:OBJECT,BOXED
|
||||
BOXED:OBJECT
|
||||
|
||||
@ -66,14 +66,23 @@ struct _GladeSignalEditorPrivate
|
||||
GtkTreeViewColumn *column_after;
|
||||
|
||||
GtkCellRenderer *renderer_userdata;
|
||||
|
||||
GtkListStore *handler_completion_store;
|
||||
};
|
||||
|
||||
enum
|
||||
{
|
||||
SIGNAL_ACTIVATED,
|
||||
CALLBACK_SUGGESTIONS,
|
||||
LAST_SIGNAL
|
||||
};
|
||||
|
||||
enum
|
||||
{
|
||||
PROP_0,
|
||||
PROP_GLADE_WIDGET
|
||||
};
|
||||
|
||||
static guint glade_signal_editor_signals[LAST_SIGNAL] = { 0 };
|
||||
|
||||
/* Utils */
|
||||
@ -178,36 +187,92 @@ on_handler_edited (GtkCellRendererText* renderer,
|
||||
gtk_tree_path_free (tree_path);
|
||||
}
|
||||
|
||||
static gchar **
|
||||
glade_signal_editor_callback_suggestions (GladeSignalEditor *editor,
|
||||
GladeSignal *signal)
|
||||
{
|
||||
GladeWidget *widget = glade_signal_editor_get_widget (editor);
|
||||
gchar *signal_name, *name, **suggestions;
|
||||
|
||||
suggestions = g_new (gchar *, 10);
|
||||
|
||||
name = (gchar *) glade_widget_get_name (widget);
|
||||
|
||||
signal_name = g_strdup (glade_signal_get_name (signal));
|
||||
glade_util_replace (signal_name, '-', '_');
|
||||
|
||||
suggestions[0] = g_strdup_printf ("on_%s_%s", name, signal_name);
|
||||
suggestions[1] = g_strdup_printf ("%s_%s_cb", name, signal_name);
|
||||
suggestions[2] = g_strdup ("gtk_widget_show");
|
||||
suggestions[3] = g_strdup ("gtk_widget_hide");
|
||||
suggestions[4] = g_strdup ("gtk_widget_grab_focus");
|
||||
suggestions[5] = g_strdup ("gtk_widget_destroy");
|
||||
suggestions[6] = g_strdup ("gtk_true");
|
||||
suggestions[7] = g_strdup ("gtk_false");
|
||||
suggestions[8] = g_strdup ("gtk_main_quit");
|
||||
suggestions[9] = NULL;
|
||||
|
||||
return suggestions;
|
||||
}
|
||||
|
||||
static void
|
||||
on_handler_editing_started (GtkCellRenderer *renderer,
|
||||
GtkCellEditable *editable,
|
||||
gchar *path,
|
||||
gpointer user_data)
|
||||
{
|
||||
GladeSignalEditor* self = GLADE_SIGNAL_EDITOR(user_data);
|
||||
GtkTreePath* tree_path = gtk_tree_path_new_from_string (path);
|
||||
|
||||
/* Remove the <Type here> */
|
||||
/* Check if editable is still an entry */
|
||||
if (GTK_IS_ENTRY (editable))
|
||||
{
|
||||
GladeSignalEditor *self = GLADE_SIGNAL_EDITOR (user_data);
|
||||
GladeSignalEditorPrivate *priv = self->priv;
|
||||
GtkEntry *entry = GTK_ENTRY (editable);
|
||||
GtkEntryCompletion *completion;
|
||||
const gchar *signal_name = NULL;
|
||||
GtkTreePath *tree_path;
|
||||
GtkTreeIter iter;
|
||||
GladeSignal *signal;
|
||||
gboolean dummy;
|
||||
gtk_tree_model_get_iter (self->priv->model,
|
||||
&iter,
|
||||
tree_path);
|
||||
gtk_tree_model_get (self->priv->model,
|
||||
&iter,
|
||||
gchar **suggestions;
|
||||
gint i;
|
||||
|
||||
tree_path = gtk_tree_path_new_from_string (path);
|
||||
gtk_tree_model_get_iter (priv->model, &iter, tree_path);
|
||||
gtk_tree_path_free (tree_path);
|
||||
|
||||
gtk_tree_model_get (priv->model, &iter,
|
||||
GLADE_SIGNAL_COLUMN_SIGNAL, &signal,
|
||||
-1);
|
||||
dummy = glade_signal_is_dummy (signal);
|
||||
if (dummy)
|
||||
{
|
||||
gtk_entry_set_text (GTK_ENTRY (editable), "");
|
||||
}
|
||||
signal_name = glade_signal_get_name (signal);
|
||||
|
||||
if (glade_signal_is_dummy (signal))
|
||||
gtk_entry_set_text (entry, "");
|
||||
|
||||
g_signal_emit (self, glade_signal_editor_signals [CALLBACK_SUGGESTIONS], 0, signal, &suggestions);
|
||||
|
||||
g_object_unref (signal);
|
||||
|
||||
if (!signal_name)
|
||||
return;
|
||||
|
||||
completion = gtk_entry_completion_new ();
|
||||
gtk_entry_completion_set_text_column (completion, 0);
|
||||
gtk_entry_completion_set_minimum_key_length (completion, 0);
|
||||
gtk_entry_completion_set_inline_completion (completion, FALSE);
|
||||
gtk_entry_completion_set_inline_selection (completion, TRUE);
|
||||
gtk_entry_completion_set_popup_completion (completion, TRUE);
|
||||
gtk_entry_set_completion (entry, NULL);
|
||||
|
||||
gtk_list_store_clear (priv->handler_completion_store);
|
||||
|
||||
for (i = 0; suggestions[i]; i++)
|
||||
{
|
||||
gtk_list_store_append (priv->handler_completion_store, &iter);
|
||||
gtk_list_store_set (priv->handler_completion_store, &iter, 0, suggestions[i], -1);
|
||||
}
|
||||
|
||||
gtk_entry_completion_set_model (completion, GTK_TREE_MODEL (priv->handler_completion_store));
|
||||
gtk_entry_set_completion (entry, completion);
|
||||
}
|
||||
gtk_tree_path_free (tree_path);
|
||||
}
|
||||
|
||||
static void
|
||||
@ -373,6 +438,45 @@ glade_signal_editor_devhelp (GtkCellRenderer * cell,
|
||||
g_object_unref (signal);
|
||||
}
|
||||
|
||||
static void
|
||||
glade_signal_editor_get_property (GObject *object,
|
||||
guint prop_id,
|
||||
GValue *value,
|
||||
GParamSpec *pspec)
|
||||
{
|
||||
GladeSignalEditor *self = GLADE_SIGNAL_EDITOR (object);
|
||||
GladeSignalEditorPrivate *priv = self->priv;
|
||||
|
||||
switch (prop_id)
|
||||
{
|
||||
case PROP_GLADE_WIDGET:
|
||||
g_value_set_object (value, priv->widget);
|
||||
break;
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
glade_signal_editor_set_property (GObject *object,
|
||||
guint prop_id,
|
||||
const GValue *value,
|
||||
GParamSpec *pspec)
|
||||
{
|
||||
GladeSignalEditor *self = GLADE_SIGNAL_EDITOR (object);
|
||||
|
||||
switch (prop_id)
|
||||
{
|
||||
case PROP_GLADE_WIDGET:
|
||||
glade_signal_editor_load_widget (self, g_value_get_object (value));
|
||||
break;
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* glade_signal_editor_new:
|
||||
*
|
||||
@ -995,6 +1099,9 @@ glade_signal_editor_init (GladeSignalEditor *self)
|
||||
G_CALLBACK(glade_signal_editor_drag_begin),
|
||||
self);
|
||||
|
||||
/* Handler completion */
|
||||
priv->handler_completion_store = gtk_list_store_new (1, G_TYPE_STRING);
|
||||
|
||||
/* Emit created signal */
|
||||
g_signal_emit_by_name (glade_app_get(), "signal-editor-created", self);
|
||||
|
||||
@ -1009,8 +1116,12 @@ glade_signal_editor_class_init (GladeSignalEditorClass *klass)
|
||||
glade_signal_editor_parent_class = g_type_class_peek_parent (klass);
|
||||
|
||||
object_class = G_OBJECT_CLASS (klass);
|
||||
object_class->get_property = glade_signal_editor_get_property;
|
||||
object_class->set_property = glade_signal_editor_set_property;
|
||||
object_class->dispose = glade_signal_editor_dispose;
|
||||
|
||||
klass->callback_suggestions = glade_signal_editor_callback_suggestions;
|
||||
|
||||
g_type_class_add_private (klass, sizeof (GladeSignalEditorPrivate));
|
||||
|
||||
/**
|
||||
@ -1028,4 +1139,34 @@ glade_signal_editor_class_init (GladeSignalEditorClass *klass)
|
||||
G_TYPE_NONE, 1,
|
||||
GLADE_TYPE_SIGNAL /* Signal data formatted string */
|
||||
);
|
||||
|
||||
/**
|
||||
* GladeSignalEditor::callback-suggestions:
|
||||
* @editor: the object which received the signal
|
||||
* @signal: the #GladeSignal that needs callbacks suggestions
|
||||
* @suggestions: Return
|
||||
*
|
||||
* Emitted when the editor needs to show a list of callbacks suggestions to the user.
|
||||
*
|
||||
* Returns wheter or not the event was handled.
|
||||
*/
|
||||
glade_signal_editor_signals[CALLBACK_SUGGESTIONS] =
|
||||
g_signal_new ("callback-suggestions",
|
||||
G_TYPE_FROM_CLASS (object_class),
|
||||
G_SIGNAL_RUN_LAST,
|
||||
G_STRUCT_OFFSET (GladeSignalEditorClass, callback_suggestions),
|
||||
_glade_strv_handled_accumulator,
|
||||
NULL, _glade_marshal_BOXED__OBJECT,
|
||||
G_TYPE_STRV, 1,
|
||||
GLADE_TYPE_SIGNAL
|
||||
);
|
||||
|
||||
|
||||
g_object_class_install_property (object_class,
|
||||
PROP_GLADE_WIDGET,
|
||||
g_param_spec_object ("glade-widget",
|
||||
"Glade Widget",
|
||||
"The glade widget to edit signals",
|
||||
GTK_TYPE_TREE_MODEL,
|
||||
G_PARAM_READWRITE));
|
||||
}
|
||||
|
||||
@ -31,6 +31,7 @@ struct _GladeSignalEditorClass
|
||||
{
|
||||
GtkVBoxClass parent_class;
|
||||
|
||||
gchar ** (* callback_suggestions) (GladeSignalEditor *editor, GladeSignal *signal);
|
||||
void (* glade_reserved1) (void);
|
||||
void (* glade_reserved2) (void);
|
||||
void (* glade_reserved3) (void);
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user