diff options
author | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2012-09-04 20:39:02 +0800 |
---|---|---|
committer | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2012-09-05 15:13:23 +0800 |
commit | 34789c7c8447174ec0881e2abbf029ae34a37c99 (patch) | |
tree | fc41f191166ef86456f97120a8bdd7e364eb59b8 | |
parent | e52959e0abfcfa322bf3e0e7587e62f1d49d8699 (diff) | |
download | gsoc2013-empathy-34789c7c8447174ec0881e2abbf029ae34a37c99.tar gsoc2013-empathy-34789c7c8447174ec0881e2abbf029ae34a37c99.tar.gz gsoc2013-empathy-34789c7c8447174ec0881e2abbf029ae34a37c99.tar.bz2 gsoc2013-empathy-34789c7c8447174ec0881e2abbf029ae34a37c99.tar.lz gsoc2013-empathy-34789c7c8447174ec0881e2abbf029ae34a37c99.tar.xz gsoc2013-empathy-34789c7c8447174ec0881e2abbf029ae34a37c99.tar.zst gsoc2013-empathy-34789c7c8447174ec0881e2abbf029ae34a37c99.zip |
display_page_message: use a flag instead of booleans
More scalable.
https://bugzilla.gnome.org/show_bug.cgi?id=683326
-rw-r--r-- | src/empathy-roster-window.c | 31 |
1 files changed, 20 insertions, 11 deletions
diff --git a/src/empathy-roster-window.c b/src/empathy-roster-window.c index ffaa6b926..465a403ad 100644 --- a/src/empathy-roster-window.c +++ b/src/empathy-roster-window.c @@ -379,11 +379,17 @@ button_account_settings_clicked_cb (GtkButton *button, NULL, FALSE, FALSE); } +typedef enum +{ + PAGE_MESSAGE_FLAG_NONE = 0, + PAGE_MESSAGE_FLAG_ACCOUNTS = 1 << 0, + PAGE_MESSAGE_FLAG_SPINNER = 1 << 2, +} PageMessageFlags; + static void display_page_message (EmpathyRosterWindow *self, const gchar *msg, - gboolean display_accounts_button, - gboolean display_spinner) + PageMessageFlags flags) { if (msg != NULL) { @@ -403,9 +409,9 @@ display_page_message (EmpathyRosterWindow *self, } gtk_widget_set_visible (self->priv->button_account_settings, - display_accounts_button); + (flags & PAGE_MESSAGE_FLAG_ACCOUNTS) != 0); gtk_widget_set_visible (self->priv->spinner_loading, - display_spinner); + (flags & PAGE_MESSAGE_FLAG_SPINNER) != 0); gtk_notebook_set_current_page (GTK_NOTEBOOK (self->priv->notebook), PAGE_MESSAGE); @@ -415,7 +421,8 @@ static void display_page_no_account (EmpathyRosterWindow *self) { display_page_message (self, - _("You need to setup an account to see contacts here."), TRUE, FALSE); + _("You need to setup an account to see contacts here."), + PAGE_MESSAGE_FLAG_ACCOUNTS); } static void @@ -1528,7 +1535,7 @@ display_page_account_not_enabled (EmpathyRosterWindow *self, { display_page_message (self, _("You need to enable one of your accounts to see contacts here."), - TRUE, FALSE); + PAGE_MESSAGE_FLAG_ACCOUNTS); } else { @@ -1538,7 +1545,7 @@ display_page_account_not_enabled (EmpathyRosterWindow *self, tmp = g_strdup_printf (_("You need to enable %s to see contacts here."), tp_account_get_display_name (account)); - display_page_message (self, tmp, TRUE, FALSE); + display_page_message (self, tmp, PAGE_MESSAGE_FLAG_ACCOUNTS); g_free (tmp); } } @@ -1596,7 +1603,7 @@ set_notebook_page (EmpathyRosterWindow *self) { display_page_message (self, _("Change your presence to see contacts here"), - FALSE, FALSE); + PAGE_MESSAGE_FLAG_NONE); goto out; } @@ -1604,11 +1611,13 @@ set_notebook_page (EmpathyRosterWindow *self) { if (empathy_roster_view_is_searching (self->priv->view)) { - display_page_message (self, _("No match found"), FALSE, FALSE); + display_page_message (self, _("No match found"), + PAGE_MESSAGE_FLAG_NONE); } else { - display_page_message (self, _("No online contacts"), FALSE, FALSE); + display_page_message (self, _("No online contacts"), + PAGE_MESSAGE_FLAG_NONE); } goto out; } @@ -1835,7 +1844,7 @@ empathy_roster_window_class_init (EmpathyRosterWindowClass *klass) static void show_contacts_loading (EmpathyRosterWindow *self) { - display_page_message (self, NULL, FALSE, TRUE); + display_page_message (self, NULL, PAGE_MESSAGE_FLAG_SPINNER); gtk_spinner_start (GTK_SPINNER (self->priv->spinner_loading)); } |