diff options
Diffstat (limited to 'shell')
-rw-r--r-- | shell/e-shell-searchbar.c | 159 |
1 files changed, 95 insertions, 64 deletions
diff --git a/shell/e-shell-searchbar.c b/shell/e-shell-searchbar.c index 5795407d0d..44b3d105ff 100644 --- a/shell/e-shell-searchbar.c +++ b/shell/e-shell-searchbar.c @@ -67,7 +67,7 @@ struct _EShellSearchbarPrivate { GtkWidget *scope_combo_box; /* Child widget containers (referenced) */ - GSList *child_containers; + GQueue child_containers; guint resize_idle_id; /* State Key File */ @@ -256,17 +256,21 @@ shell_searchbar_update_search_widgets (EShellSearchbar *searchbar) gchar *css; style = gtk_widget_get_style_context (widget); - gtk_style_context_get_background_color (style, GTK_STATE_FLAG_SELECTED, &bg); - gtk_style_context_get_color (style, GTK_STATE_FLAG_SELECTED, &fg); - - css = g_strdup_printf ("GtkEntry#searchbar_searchentry_active { " - " background:none; " - " background-color:#%06x; " - " color:#%06x; " - "}", - e_rgba_to_value (&bg), - e_rgba_to_value (&fg)); - gtk_css_provider_load_from_data (searchbar->priv->css_provider, css, -1, NULL); + gtk_style_context_get_background_color ( + style, GTK_STATE_FLAG_SELECTED, &bg); + gtk_style_context_get_color ( + style, GTK_STATE_FLAG_SELECTED, &fg); + + css = g_strdup_printf ( + "GtkEntry#searchbar_searchentry_active { " + " background:none; " + " background-color:#%06x; " + " color:#%06x; " + "}", + e_rgba_to_value (&bg), + e_rgba_to_value (&fg)); + gtk_css_provider_load_from_data ( + searchbar->priv->css_provider, css, -1, NULL); g_free (css); gtk_widget_set_name (widget, "searchbar_searchentry_active"); @@ -465,9 +469,9 @@ shell_searchbar_option_changed_cb (GtkRadioAction *action, if (current_value != SEARCH_OPTION_ADVANCED) { e_shell_view_set_search_rule (shell_view, NULL); e_shell_searchbar_set_search_text (searchbar, search_text); - if (search_text != NULL && *search_text != '\0') + if (search_text != NULL && *search_text != '\0') { e_shell_view_execute_search (shell_view); - else { + } else { shell_searchbar_save_search_option (searchbar); gtk_widget_grab_focus (searchbar->priv->search_entry); } @@ -481,21 +485,29 @@ shell_searchbar_resize_idle_cb (gpointer user_data) { GtkWidget *widget; EShellSearchbar *searchbar; - GSList *iter, *widths = NULL, *witer; - gint row, column, roww, maxw, child_left, child_top, allocated_width; + GQueue *child_containers; + GList *head, *link; + GArray *widths; + gint row = 0; + gint column = 0; + gint roww = 0; + gint maxw = 0; + gint child_left; + gint child_top; + gint allocated_width; gboolean needs_reposition = FALSE; - widget = user_data; - searchbar = E_SHELL_SEARCHBAR (widget); + widget = GTK_WIDGET (user_data); allocated_width = gtk_widget_get_allocated_width (widget); - row = 0; - column = 0; - roww = 0; - maxw = 0; + searchbar = E_SHELL_SEARCHBAR (widget); + child_containers = &searchbar->priv->child_containers; + head = g_queue_peek_head_link (child_containers); + + widths = g_array_new (FALSE, FALSE, sizeof (gint)); - for (iter = searchbar->priv->child_containers; iter != NULL; iter = iter->next) { - GtkWidget *child = iter->data; + for (link = head; link != NULL; link = g_list_next (link)) { + GtkWidget *child = GTK_WIDGET (link->data); gint minw = -1; if (!gtk_widget_get_visible (child)) @@ -503,7 +515,7 @@ shell_searchbar_resize_idle_cb (gpointer user_data) else gtk_widget_get_preferred_width (child, &minw, NULL); - widths = g_slist_append (widths, GINT_TO_POINTER (minw)); + g_array_append_val (widths, minw); if (roww && minw) { roww += COLUMN_SPACING; @@ -527,26 +539,37 @@ shell_searchbar_resize_idle_cb (gpointer user_data) "top-attach", &child_top, NULL); - needs_reposition = needs_reposition || child_left != column || child_top != row; + needs_reposition |= + (child_left != column) || + (child_top != row); if (column == 0 && row > 0 && roww < maxw) { - /* columns has same width, thus use the wider widget for calculations*/ + /* Columns have the same width, so use + * the wider widget for calculations. */ roww = maxw; } } if (needs_reposition) { + guint ii = 0; + row = 0; column = 0; roww = 0; - for (iter = searchbar->priv->child_containers; iter; iter = iter->next) { - gtk_container_remove (GTK_CONTAINER (widget), iter->data); - } + g_warn_if_fail (child_containers->length == widths->len); + + for (link = head; link != NULL; link = g_list_next (link)) + gtk_container_remove ( + GTK_CONTAINER (widget), + GTK_WIDGET (link->data)); - for (witer = widths, iter = searchbar->priv->child_containers; witer && iter; witer = witer->next, iter = iter->next) { - GtkWidget *child = iter->data; - gint w = GPOINTER_TO_INT (witer->data); + for (link = head; link != NULL; link = g_list_next (link)) { + GtkWidget *child; + gint w; + + child = GTK_WIDGET (link->data); + w = g_array_index (widths, gint, ii++); if (roww && w) { roww += COLUMN_SPACING; @@ -561,17 +584,17 @@ shell_searchbar_resize_idle_cb (gpointer user_data) column = 0; } - gtk_grid_attach (GTK_GRID (widget), child, column, row, 1, 1); + gtk_grid_attach ( + GTK_GRID (widget), child, column, row, 1, 1); if (column == 0 && row > 0 && roww < maxw) roww = maxw; } } - g_slist_free (widths); + g_array_free (widths, TRUE); searchbar->priv->resize_idle_id = 0; - g_object_unref (searchbar); return FALSE; } @@ -771,16 +794,11 @@ shell_searchbar_dispose (GObject *object) priv = E_SHELL_SEARCHBAR_GET_PRIVATE (object); - if (priv->resize_idle_id) { + if (priv->resize_idle_id > 0) { g_source_remove (priv->resize_idle_id); priv->resize_idle_id = 0; } - if (priv->child_containers) { - g_slist_free_full (priv->child_containers, g_object_unref); - priv->child_containers = NULL; - } - if (priv->shell_view != NULL) { g_object_remove_weak_pointer ( G_OBJECT (priv->shell_view), &priv->shell_view); @@ -791,25 +809,32 @@ shell_searchbar_dispose (GObject *object) g_signal_handlers_disconnect_matched ( priv->search_option, G_SIGNAL_MATCH_DATA, 0, 0, NULL, NULL, object); - g_object_unref (priv->search_option); - priv->search_option = NULL; + g_clear_object (&priv->search_option); } - if (priv->state_group) { - g_free (priv->state_group); - priv->state_group = NULL; - } + g_clear_object (&priv->css_provider); - if (priv->css_provider) { - g_object_unref (priv->css_provider); - priv->css_provider = NULL; - } + while (!g_queue_is_empty (&priv->child_containers)) + g_object_unref (g_queue_pop_head (&priv->child_containers)); /* Chain up to parent's dispose() method. */ G_OBJECT_CLASS (e_shell_searchbar_parent_class)->dispose (object); } static void +shell_searchbar_finalize (GObject *object) +{ + EShellSearchbarPrivate *priv; + + priv = E_SHELL_SEARCHBAR_GET_PRIVATE (object); + + g_free (priv->state_group); + + /* Chain up to parent's finalize() method. */ + G_OBJECT_CLASS (e_shell_searchbar_parent_class)->finalize (object); +} + +static void shell_searchbar_constructed (GObject *object) { EShellView *shell_view; @@ -908,14 +933,17 @@ static void shell_searchbar_size_allocate (GtkWidget *widget, GdkRectangle *allocation) { - EShellSearchbar *searchbar; + EShellSearchbarPrivate *priv; - GTK_WIDGET_CLASS (e_shell_searchbar_parent_class)->size_allocate (widget, allocation); + priv = E_SHELL_SEARCHBAR_GET_PRIVATE (widget); - searchbar = E_SHELL_SEARCHBAR (widget); + /* Chain up to parent's size_allocate() method. */ + GTK_WIDGET_CLASS (e_shell_searchbar_parent_class)-> + size_allocate (widget, allocation); - if (!searchbar->priv->resize_idle_id) - searchbar->priv->resize_idle_id = g_idle_add (shell_searchbar_resize_idle_cb, g_object_ref (searchbar)); + if (priv->resize_idle_id == 0) + priv->resize_idle_id = g_idle_add ( + shell_searchbar_resize_idle_cb, widget); } static void @@ -958,6 +986,7 @@ e_shell_searchbar_class_init (EShellSearchbarClass *class) object_class->set_property = shell_searchbar_set_property; object_class->get_property = shell_searchbar_get_property; object_class->dispose = shell_searchbar_dispose; + object_class->finalize = shell_searchbar_finalize; object_class->constructed = shell_searchbar_constructed; widget_class = GTK_WIDGET_CLASS (class); @@ -1109,9 +1138,11 @@ e_shell_searchbar_init (EShellSearchbar *searchbar) GtkGrid *grid; GtkLabel *label; GtkWidget *widget; + GQueue *child_containers; searchbar->priv = E_SHELL_SEARCHBAR_GET_PRIVATE (searchbar); - searchbar->priv->child_containers = NULL; + + child_containers = &searchbar->priv->child_containers; gtk_grid_set_column_spacing (GTK_GRID (searchbar), COLUMN_SPACING); gtk_grid_set_row_spacing (GTK_GRID (searchbar), 4); @@ -1128,8 +1159,8 @@ e_shell_searchbar_init (EShellSearchbar *searchbar) "valign", GTK_ALIGN_CENTER, NULL); gtk_grid_attach (grid, widget, 0, 0, 1, 1); - searchbar->priv->child_containers = g_slist_append ( - searchbar->priv->child_containers, g_object_ref (widget)); + + g_queue_push_tail (child_containers, g_object_ref (widget)); g_object_bind_property ( searchbar, "filter-visible", @@ -1173,8 +1204,8 @@ e_shell_searchbar_init (EShellSearchbar *searchbar) "hexpand", TRUE, NULL); gtk_grid_attach (grid, widget, 1, 0, 1, 1); - searchbar->priv->child_containers = g_slist_append ( - searchbar->priv->child_containers, g_object_ref (widget)); + + g_queue_push_tail (child_containers, g_object_ref (widget)); g_object_bind_property ( searchbar, "search-visible", @@ -1259,8 +1290,8 @@ e_shell_searchbar_init (EShellSearchbar *searchbar) "valign", GTK_ALIGN_CENTER, NULL); gtk_grid_attach (grid, widget, 2, 0, 1, 1); - searchbar->priv->child_containers = g_slist_append ( - searchbar->priv->child_containers, g_object_ref (widget)); + + g_queue_push_tail (child_containers, g_object_ref (widget)); g_object_bind_property ( searchbar, "scope-visible", |