[gimp/gtk3-port: 152/391] libgimpwidgets: move all GimpBrowser members to a private struct
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/gtk3-port: 152/391] libgimpwidgets: move all GimpBrowser members to a private struct
- Date: Thu, 10 May 2018 16:03:24 +0000 (UTC)
commit 70b8dbb2b6ce8cfc47eaf85e85b092aa851b602a
Author: Michael Natterer <mitch gimp org>
Date: Fri Dec 31 18:19:37 2010 +0100
libgimpwidgets: move all GimpBrowser members to a private struct
The newly added API is ugly and will change.
libgimp/gimpprocbrowserdialog.c | 10 +-
libgimpwidgets/gimpbrowser.c | 220 ++++++++++++++++++++++++++++----------
libgimpwidgets/gimpbrowser.h | 40 +++----
plug-ins/common/plugin-browser.c | 6 +-
4 files changed, 187 insertions(+), 89 deletions(-)
---
diff --git a/libgimp/gimpprocbrowserdialog.c b/libgimp/gimpprocbrowserdialog.c
index 3a69f64..f560577 100644
--- a/libgimp/gimpprocbrowserdialog.c
+++ b/libgimp/gimpprocbrowserdialog.c
@@ -172,7 +172,7 @@ gimp_proc_browser_dialog_init (GimpProcBrowserDialog *dialog)
gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window),
GTK_POLICY_AUTOMATIC,
GTK_POLICY_ALWAYS);
- gtk_box_pack_start (GTK_BOX (GIMP_BROWSER (dialog->browser)->left_vbox),
+ gtk_box_pack_start (GTK_BOX (gimp_browser_get_left_vbox (GIMP_BROWSER (dialog->browser))),
scrolled_window, TRUE, TRUE, 0);
gtk_widget_show (scrolled_window);
@@ -203,7 +203,7 @@ gimp_proc_browser_dialog_init (GimpProcBrowserDialog *dialog)
G_CALLBACK (browser_selection_changed),
dialog);
- parent = gtk_widget_get_parent (GIMP_BROWSER (dialog->browser)->right_vbox);
+ parent = gtk_widget_get_parent (gimp_browser_get_right_vbox (GIMP_BROWSER (dialog->browser)));
parent = gtk_widget_get_parent (parent);
gtk_widget_set_size_request (parent, DBL_WIDTH - DBL_LIST_WIDTH, -1);
@@ -394,8 +394,8 @@ browser_search (GimpBrowser *browser,
gimp_browser_show_message (browser, _("No matches"));
- gtk_label_set_text (GTK_LABEL (browser->count_label),
- _("Search term invalid or incomplete"));
+ gimp_browser_set_search_summary (browser,
+ _("Search term invalid or incomplete"));
return;
}
@@ -501,7 +501,7 @@ browser_search (GimpBrowser *browser,
}
}
- gtk_label_set_text (GTK_LABEL (browser->count_label), str);
+ gimp_browser_set_search_summary (browser, str);
g_free (str);
if (num_procs > 0)
diff --git a/libgimpwidgets/gimpbrowser.c b/libgimpwidgets/gimpbrowser.c
index 1d1e1d8..be27692 100644
--- a/libgimpwidgets/gimpbrowser.c
+++ b/libgimpwidgets/gimpbrowser.c
@@ -50,6 +50,29 @@ enum
};
+typedef struct _GimpBrowserPrivate GimpBrowserPrivate;
+
+struct _GimpBrowserPrivate
+{
+ GtkWidget *left_vbox;
+
+ GtkWidget *search_entry;
+ guint search_timeout_id;
+
+ GtkWidget *search_type_combo;
+ gint search_type;
+
+ GtkWidget *count_label;
+
+ GtkWidget *right_vbox;
+ GtkWidget *right_widget;
+};
+
+#define GET_PRIVATE(obj) G_TYPE_INSTANCE_GET_PRIVATE (obj, \
+ GIMP_TYPE_BROWSER, \
+ GimpBrowserPrivate)
+
+
static void gimp_browser_dispose (GObject *object);
static void gimp_browser_combo_changed (GtkComboBox *combo,
@@ -63,7 +86,7 @@ static void gimp_browser_entry_icon_press (GtkEntry *entry,
static gboolean gimp_browser_search_timeout (gpointer data);
-G_DEFINE_TYPE (GimpBrowser, gimp_browser, GTK_TYPE_HPANED)
+G_DEFINE_TYPE (GimpBrowser, gimp_browser, GTK_TYPE_PANED)
#define parent_class gimp_browser_parent_class
@@ -89,63 +112,69 @@ gimp_browser_class_init (GimpBrowserClass *klass)
object_class->dispose = gimp_browser_dispose;
klass->search = NULL;
+
+ g_type_class_add_private (object_class, sizeof (GimpBrowserPrivate));
}
static void
gimp_browser_init (GimpBrowser *browser)
{
- GtkWidget *hbox;
- GtkWidget *label;
- GtkWidget *scrolled_window;
- GtkWidget *viewport;
+ GimpBrowserPrivate *priv = GET_PRIVATE (browser);
+ GtkWidget *hbox;
+ GtkWidget *label;
+ GtkWidget *scrolled_window;
+ GtkWidget *viewport;
- browser->search_type = -1;
+ gtk_orientable_set_orientation (GTK_ORIENTABLE (browser),
+ GTK_ORIENTATION_HORIZONTAL);
- browser->left_vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 6);
- gtk_paned_pack1 (GTK_PANED (browser), browser->left_vbox, FALSE, TRUE);
- gtk_widget_show (browser->left_vbox);
+ priv->search_type = -1;
+
+ priv->left_vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 6);
+ gtk_paned_pack1 (GTK_PANED (browser), priv->left_vbox, FALSE, TRUE);
+ gtk_widget_show (priv->left_vbox);
/* search entry */
hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 6);
- gtk_box_pack_start (GTK_BOX (browser->left_vbox), hbox, FALSE, FALSE, 0);
+ gtk_box_pack_start (GTK_BOX (priv->left_vbox), hbox, FALSE, FALSE, 0);
gtk_widget_show (hbox);
label = gtk_label_new_with_mnemonic (_("_Search:"));
gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
gtk_widget_show (label);
- browser->search_entry = gtk_entry_new ();
- gtk_box_pack_start (GTK_BOX (hbox), browser->search_entry, TRUE, TRUE, 0);
- gtk_widget_show (browser->search_entry);
+ priv->search_entry = gtk_entry_new ();
+ gtk_box_pack_start (GTK_BOX (hbox), priv->search_entry, TRUE, TRUE, 0);
+ gtk_widget_show (priv->search_entry);
- gtk_label_set_mnemonic_widget (GTK_LABEL (label), browser->search_entry);
+ gtk_label_set_mnemonic_widget (GTK_LABEL (label), priv->search_entry);
- g_signal_connect (browser->search_entry, "changed",
+ g_signal_connect (priv->search_entry, "changed",
G_CALLBACK (gimp_browser_entry_changed),
browser);
- gtk_entry_set_icon_from_icon_name (GTK_ENTRY (browser->search_entry),
+ gtk_entry_set_icon_from_icon_name (GTK_ENTRY (priv->search_entry),
GTK_ENTRY_ICON_SECONDARY, "edit-clear");
- gtk_entry_set_icon_activatable (GTK_ENTRY (browser->search_entry),
+ gtk_entry_set_icon_activatable (GTK_ENTRY (priv->search_entry),
GTK_ENTRY_ICON_SECONDARY, TRUE);
- gtk_entry_set_icon_sensitive (GTK_ENTRY (browser->search_entry),
+ gtk_entry_set_icon_sensitive (GTK_ENTRY (priv->search_entry),
GTK_ENTRY_ICON_SECONDARY, FALSE);
- g_signal_connect (browser->search_entry, "icon-press",
+ g_signal_connect (priv->search_entry, "icon-press",
G_CALLBACK (gimp_browser_entry_icon_press),
browser);
/* count label */
- browser->count_label = gtk_label_new (_("No matches"));
- gtk_label_set_xalign (GTK_LABEL (browser->count_label), 0.0);
- gimp_label_set_attributes (GTK_LABEL (browser->count_label),
+ priv->count_label = gtk_label_new (_("No matches"));
+ gtk_label_set_xalign (GTK_LABEL (priv->count_label), 0.0);
+ gimp_label_set_attributes (GTK_LABEL (priv->count_label),
PANGO_ATTR_STYLE, PANGO_STYLE_ITALIC,
-1);
- gtk_box_pack_end (GTK_BOX (browser->left_vbox), browser->count_label,
+ gtk_box_pack_end (GTK_BOX (priv->left_vbox), priv->count_label,
FALSE, FALSE, 0);
- gtk_widget_show (browser->count_label);
+ gtk_widget_show (priv->count_label);
/* scrolled window */
@@ -160,23 +189,23 @@ gimp_browser_init (GimpBrowser *browser)
gtk_container_add (GTK_CONTAINER (scrolled_window), viewport);
gtk_widget_show (viewport);
- browser->right_vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0);
- gtk_container_set_border_width (GTK_CONTAINER (browser->right_vbox), 12);
- gtk_container_add (GTK_CONTAINER (viewport), browser->right_vbox);
- gtk_widget_show (browser->right_vbox);
+ priv->right_vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0);
+ gtk_container_set_border_width (GTK_CONTAINER (priv->right_vbox), 12);
+ gtk_container_add (GTK_CONTAINER (viewport), priv->right_vbox);
+ gtk_widget_show (priv->right_vbox);
- gtk_widget_grab_focus (browser->search_entry);
+ gtk_widget_grab_focus (priv->search_entry);
}
static void
gimp_browser_dispose (GObject *object)
{
- GimpBrowser *browser = GIMP_BROWSER (object);
+ GimpBrowserPrivate *priv = GET_PRIVATE (object);
- if (browser->search_timeout_id)
+ if (priv->search_timeout_id)
{
- g_source_remove (browser->search_timeout_id);
- browser->search_timeout_id = 0;
+ g_source_remove (priv->search_timeout_id);
+ priv->search_timeout_id = 0;
}
G_OBJECT_CLASS (parent_class)->dispose (object);
@@ -218,10 +247,14 @@ gimp_browser_add_search_types (GimpBrowser *browser,
gint first_type_id,
...)
{
+ GimpBrowserPrivate *priv;
+
g_return_if_fail (GIMP_IS_BROWSER (browser));
g_return_if_fail (first_type_label != NULL);
- if (! browser->search_type_combo)
+ priv = GET_PRIVATE (browser);
+
+ if (! priv->search_type_combo)
{
GtkWidget *combo;
va_list args;
@@ -234,17 +267,17 @@ gimp_browser_add_search_types (GimpBrowser *browser,
gtk_combo_box_set_focus_on_click (GTK_COMBO_BOX (combo), FALSE);
- browser->search_type_combo = combo;
- browser->search_type = first_type_id;
+ priv->search_type_combo = combo;
+ priv->search_type = first_type_id;
- gtk_box_pack_end (GTK_BOX (gtk_widget_get_parent (browser->search_entry)),
+ gtk_box_pack_end (GTK_BOX (gtk_widget_get_parent (priv->search_entry)),
combo, FALSE, FALSE, 0);
gtk_widget_show (combo);
gimp_int_combo_box_connect (GIMP_INT_COMBO_BOX (combo),
- browser->search_type,
+ priv->search_type,
G_CALLBACK (gimp_int_combo_box_get_active),
- &browser->search_type);
+ &priv->search_type);
g_signal_connect (combo, "changed",
G_CALLBACK (gimp_browser_combo_changed),
@@ -252,13 +285,76 @@ gimp_browser_add_search_types (GimpBrowser *browser,
}
else
{
- gimp_int_combo_box_append (GIMP_INT_COMBO_BOX (browser->search_type_combo),
+ gimp_int_combo_box_append (GIMP_INT_COMBO_BOX (priv->search_type_combo),
first_type_label, first_type_id,
NULL);
}
}
/**
+ * gimp_browser_get_left_vbox:
+ * @browser: a #GimpBrowser widget
+ *
+ * Returns: The left vbox.
+ *
+ * Since: GIMP 3.0
+ **/
+GtkWidget *
+gimp_browser_get_left_vbox (GimpBrowser *browser)
+{
+ GimpBrowserPrivate *priv;
+
+ g_return_val_if_fail (GIMP_IS_BROWSER (browser), NULL);
+
+ priv = GET_PRIVATE (browser);
+
+ return priv->left_vbox;
+}
+
+/**
+ * gimp_browser_get_right_vbox:
+ * @browser: a #GimpBrowser widget
+ *
+ * Returns: The right vbox.
+ *
+ * Since: GIMP 3.0
+ **/
+GtkWidget *
+gimp_browser_get_right_vbox (GimpBrowser *browser)
+{
+ GimpBrowserPrivate *priv;
+
+ g_return_val_if_fail (GIMP_IS_BROWSER (browser), NULL);
+
+ priv = GET_PRIVATE (browser);
+
+ return priv->right_vbox;
+}
+
+/**
+ * gimp_browser_set_search_summary:
+ * @browser: a #GimpBrowser widget
+ * @summary: a string describing the search result
+ *
+ * Sets the search summary text.
+ *
+ * Since: GIMP 3.0
+ **/
+void
+gimp_browser_set_search_summary (GimpBrowser *browser,
+ const gchar *summary)
+{
+ GimpBrowserPrivate *priv;
+
+ g_return_if_fail (GIMP_IS_BROWSER (browser));
+ g_return_if_fail (summary != NULL);
+
+ priv = GET_PRIVATE (browser);
+
+ gtk_label_set_text (GTK_LABEL (priv->count_label), summary);
+}
+
+/**
* gimp_browser_set_widget:
* @browser: a #GimpBrowser widget
* @widget: a #GtkWidget
@@ -271,21 +367,25 @@ void
gimp_browser_set_widget (GimpBrowser *browser,
GtkWidget *widget)
{
+ GimpBrowserPrivate *priv;
+
g_return_if_fail (GIMP_IS_BROWSER (browser));
g_return_if_fail (widget == NULL || GTK_IS_WIDGET (widget));
- if (widget == browser->right_widget)
+ priv = GET_PRIVATE (browser);
+
+ if (widget == priv->right_widget)
return;
- if (browser->right_widget)
- gtk_container_remove (GTK_CONTAINER (browser->right_vbox),
- browser->right_widget);
+ if (priv->right_widget)
+ gtk_container_remove (GTK_CONTAINER (priv->right_vbox),
+ priv->right_widget);
- browser->right_widget = widget;
+ priv->right_widget = widget;
if (widget)
{
- gtk_box_pack_start (GTK_BOX (browser->right_vbox), widget,
+ gtk_box_pack_start (GTK_BOX (priv->right_vbox), widget,
FALSE, FALSE, 0);
gtk_widget_show (widget);
}
@@ -306,12 +406,16 @@ void
gimp_browser_show_message (GimpBrowser *browser,
const gchar *message)
{
+ GimpBrowserPrivate *priv;
+
g_return_if_fail (GIMP_IS_BROWSER (browser));
g_return_if_fail (message != NULL);
- if (GTK_IS_LABEL (browser->right_widget))
+ priv = GET_PRIVATE (browser);
+
+ if (GTK_IS_LABEL (priv->right_widget))
{
- gtk_label_set_text (GTK_LABEL (browser->right_widget), message);
+ gtk_label_set_text (GTK_LABEL (priv->right_widget), message);
}
else
{
@@ -333,10 +437,12 @@ gimp_browser_show_message (GimpBrowser *browser,
static void
gimp_browser_queue_search (GimpBrowser *browser)
{
- if (browser->search_timeout_id)
- g_source_remove (browser->search_timeout_id);
+ GimpBrowserPrivate *priv = GET_PRIVATE (browser);
+
+ if (priv->search_timeout_id)
+ g_source_remove (priv->search_timeout_id);
- browser->search_timeout_id =
+ priv->search_timeout_id =
g_timeout_add (100, gimp_browser_search_timeout, browser);
}
@@ -375,20 +481,20 @@ gimp_browser_entry_icon_press (GtkEntry *entry,
static gboolean
gimp_browser_search_timeout (gpointer data)
{
- GimpBrowser *browser = GIMP_BROWSER (data);
- const gchar *search_string;
+ GimpBrowserPrivate *priv = GET_PRIVATE (data);
+ const gchar *search_string;
GDK_THREADS_ENTER();
- search_string = gtk_entry_get_text (GTK_ENTRY (browser->search_entry));
+ search_string = gtk_entry_get_text (GTK_ENTRY (priv->search_entry));
if (! search_string)
search_string = "";
- g_signal_emit (browser, browser_signals[SEARCH], 0,
- search_string, browser->search_type);
+ g_signal_emit (data, browser_signals[SEARCH], 0,
+ search_string, priv->search_type);
- browser->search_timeout_id = 0;
+ priv->search_timeout_id = 0;
GDK_THREADS_LEAVE();
diff --git a/libgimpwidgets/gimpbrowser.h b/libgimpwidgets/gimpbrowser.h
index 0837aa6..af8b60c 100644
--- a/libgimpwidgets/gimpbrowser.h
+++ b/libgimpwidgets/gimpbrowser.h
@@ -43,25 +43,12 @@ typedef struct _GimpBrowserClass GimpBrowserClass;
struct _GimpBrowser
{
- GtkHPaned parent_instance;
-
- GtkWidget *left_vbox;
-
- GtkWidget *search_entry;
- guint search_timeout_id;
-
- GtkWidget *search_type_combo;
- gint search_type;
-
- GtkWidget *count_label;
-
- GtkWidget *right_vbox;
- GtkWidget *right_widget;
+ GtkPaned parent_instance;
};
struct _GimpBrowserClass
{
- GtkHPanedClass parent_class;
+ GtkPanedClass parent_class;
void (* search) (GimpBrowser *browser,
const gchar *search_string,
@@ -77,17 +64,22 @@ struct _GimpBrowserClass
GType gimp_browser_get_type (void) G_GNUC_CONST;
-GtkWidget * gimp_browser_new (void);
+GtkWidget * gimp_browser_new (void);
+
+void gimp_browser_add_search_types (GimpBrowser *browser,
+ const gchar *first_type_label,
+ gint first_type_id,
+ ...) G_GNUC_NULL_TERMINATED;
-void gimp_browser_add_search_types (GimpBrowser *browser,
- const gchar *first_type_label,
- gint first_type_id,
- ...) G_GNUC_NULL_TERMINATED;
+GtkWidget * gimp_browser_get_left_vbox (GimpBrowser *browser);
+GtkWidget * gimp_browser_get_right_vbox (GimpBrowser *browser);
-void gimp_browser_set_widget (GimpBrowser *browser,
- GtkWidget *widget);
-void gimp_browser_show_message (GimpBrowser *browser,
- const gchar *message);
+void gimp_browser_set_search_summary (GimpBrowser *browser,
+ const gchar *summary);
+void gimp_browser_set_widget (GimpBrowser *browser,
+ GtkWidget *widget);
+void gimp_browser_show_message (GimpBrowser *browser,
+ const gchar *message);
G_END_DECLS
diff --git a/plug-ins/common/plugin-browser.c b/plug-ins/common/plugin-browser.c
index ae93cce..83ba95d 100644
--- a/plug-ins/common/plugin-browser.c
+++ b/plug-ins/common/plugin-browser.c
@@ -393,7 +393,7 @@ browser_search (GimpBrowser *gimp_browser,
}
}
- gtk_label_set_text (GTK_LABEL (gimp_browser->count_label), str);
+ gimp_browser_set_search_summary (gimp_browser, str);
g_free (str);
list_store = GTK_LIST_STORE (gtk_tree_view_get_model (browser->list_view));
@@ -568,7 +568,7 @@ browser_dialog_new (void)
/* left = notebook */
notebook = gtk_notebook_new ();
- gtk_box_pack_start (GTK_BOX (GIMP_BROWSER (browser->browser)->left_vbox),
+ gtk_box_pack_start (GTK_BOX (gimp_browser_get_left_vbox (GIMP_BROWSER (browser->browser))),
notebook, TRUE, TRUE, 0);
/* list : list in a scrolled_win */
@@ -706,7 +706,7 @@ browser_dialog_new (void)
gtk_widget_show (scrolled_window);
gtk_widget_show (notebook);
- parent = gtk_widget_get_parent (GIMP_BROWSER (browser->browser)->right_vbox);
+ parent = gtk_widget_get_parent (gimp_browser_get_right_vbox (GIMP_BROWSER (browser->browser)));
parent = gtk_widget_get_parent (parent);
gtk_widget_set_size_request (parent, DBL_WIDTH - DBL_LIST_WIDTH, -1);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]