X-Git-Url: https://git.wpitchoune.net/gitweb/?a=blobdiff_plain;f=src%2Fui_status.c;h=bb46c2bfc2177f1c959bb81bea64b319e0f40a06;hb=573a01a68ca7cfc7c0afc6c128737dd05dd11625;hp=39fe77dcacd6e500f349655e8027d60b21eb857b;hpb=e09566298bb2c44bed1d1401252fb7863c8d2de0;p=psensor.git diff --git a/src/ui_status.c b/src/ui_status.c index 39fe77d..bb46c2b 100644 --- a/src/ui_status.c +++ b/src/ui_status.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2010-2011 jeanfi@gmail.com + * Copyright (C) 2010-2014 jeanfi@gmail.com * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as @@ -16,18 +16,19 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA */ - -#include "log.h" +#include #include "ui_status.h" +static const char *ICON = "psensor_normal"; +static const char *ATTENTION_ICON = "psensor_hot"; + static GtkStatusIcon *status; -static unsigned status_attention; +static unsigned int status_attention; static void cb_activate(GtkStatusIcon *icon, gpointer data) { - log_printf(LOG_DEBUG, "cb_activate()"); - + log_debug("cb_activate()"); ui_window_show((struct ui_psensor *)data); } @@ -36,19 +37,19 @@ static void cb_popup_menu(GtkStatusIcon *icon, guint activate_time, gpointer data) { - log_printf(LOG_DEBUG, "cb_popup_menu()"); + log_debug("cb_popup_menu()"); } void ui_status_init(struct ui_psensor *ui) { if (status) - return ; - - log_printf(LOG_DEBUG, "ui_status_create()"); + return; + + log_debug("ui_status_create()"); status = gtk_status_icon_new(); - gtk_status_icon_set_from_icon_name(status, "psensor_normal"); - gtk_status_icon_set_visible(status, TRUE); + gtk_status_icon_set_from_icon_name(status, ICON); + ui_status_set_visible(0); g_signal_connect(G_OBJECT(status), "popup-menu", @@ -61,31 +62,49 @@ void ui_status_init(struct ui_psensor *ui) ui); } -int is_status_supported() +int is_status_supported(void) { - return gtk_status_icon_is_embedded(status); + return status && gtk_status_icon_is_embedded(status); } -void ui_status_cleanup() +void ui_status_cleanup(void) { - log_printf(LOG_DEBUG, "ui_status_cleanup()"); + log_debug("ui_status_cleanup()"); - g_object_unref(G_OBJECT(status)); + if (status) { + g_object_unref(G_OBJECT(status)); + status = NULL; + } } void ui_status_update(struct ui_psensor *ui, unsigned int attention) { - log_printf(LOG_DEBUG, "ui_status_update()"); + log_debug("ui_status_update()"); if (status_attention && !attention) - gtk_status_icon_set_from_icon_name(status, "psensor_normal"); + gtk_status_icon_set_from_icon_name(status, ICON); else if (!status_attention && attention) - gtk_status_icon_set_from_icon_name(status, "psensor_hot"); + gtk_status_icon_set_from_icon_name(status, ATTENTION_ICON); status_attention = attention; } -GtkStatusIcon *ui_status_get_icon() +GtkStatusIcon *ui_status_get_icon(struct ui_psensor *ui) { + if (!status) + ui_status_init(ui); + return status; } + +void ui_status_set_visible(unsigned int visible) +{ + log_debug("ui_status_set_visible(%d)", visible); + + if (status) { + if (visible) + gtk_status_icon_set_visible(status, TRUE); + else + gtk_status_icon_set_visible(status, FALSE); + } +}