normalized include
[psensor.git] / src / ui_pref.c
index 5494777..1db60a5 100644 (file)
 #include <stdlib.h>
 #include <string.h>
 
-#include <ui.h>
+#include <amd.h>
 #include <cfg.h>
 #include <graph.h>
-#include <ui_pref.h>
-#include <ui_color.h>
+#include <hdd.h>
+#include <lmsensor.h>
+#include <nvidia.h>
+#include <pgtop2.h>
+#include <pudisks2.h>
 #include <pxdg.h>
+#include <ui.h>
+#include <ui_color.h>
+#include <ui_pref.h>
+#include <ui_unity.h>
+
+void ui_pref_decoration_toggled_cbk(GtkToggleButton *btn, gpointer data)
+{
+       config_set_window_decoration_enabled
+               (!config_is_window_decoration_enabled());
+}
 
 GdkRGBA color_to_GdkRGBA(struct color *color)
 {
@@ -124,7 +137,7 @@ void ui_pref_dialog_run(struct ui_psensor *ui)
        w_hide_window_decoration = GTK_TOGGLE_BUTTON
                (gtk_builder_get_object(builder, "hide_window_decoration"));
        gtk_toggle_button_set_active(w_hide_window_decoration,
-                                    !cfg->window_decoration_enabled);
+                                    !config_is_window_decoration_enabled());
 
        w_keep_window_below = GTK_TOGGLE_BUTTON
                (gtk_builder_get_object(builder, "keep_window_below"));
@@ -144,6 +157,16 @@ void ui_pref_dialog_run(struct ui_psensor *ui)
        gtk_toggle_button_set_active(w_enable_launcher_counter,
                                     !cfg->unity_launcher_count_disabled);
 
+       if (ui_unity_is_supported()) {
+               gtk_widget_set_has_tooltip
+                       (GTK_WIDGET(w_enable_launcher_counter), FALSE);
+       } else {
+               gtk_widget_set_sensitive
+                       (GTK_WIDGET(w_enable_launcher_counter), FALSE);
+               gtk_widget_set_has_tooltip
+                       (GTK_WIDGET(w_enable_launcher_counter), TRUE);
+       }
+
        w_smooth_curves = GTK_TOGGLE_BUTTON
                (gtk_builder_get_object(builder, "graph_smooth_curves"));
        gtk_toggle_button_set_active(w_smooth_curves,
@@ -180,29 +203,50 @@ void ui_pref_dialog_run(struct ui_psensor *ui)
                                                           "lmsensors"));
        gtk_toggle_button_set_active(w_lmsensors, config_is_lmsensor_enabled());
 
+       if (lmsensor_is_supported()) {
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_lmsensors), FALSE);
+       } else {
+               gtk_widget_set_sensitive(GTK_WIDGET(w_lmsensors), 0);
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_lmsensors), TRUE);
+       }
+
        w_nvctrl
                = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
                                                           "nvctrl"));
-#if !HAVE_NVIDIA
-       gtk_widget_set_sensitive(GTK_WIDGET(w_nvctrl), 0);
-#endif
+
+       if (nvidia_is_supported()) {
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_nvctrl), FALSE);
+       } else {
+               gtk_widget_set_sensitive(GTK_WIDGET(w_nvctrl), 0);
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_nvctrl), TRUE);
+       }
+
        gtk_toggle_button_set_active(w_nvctrl, config_is_nvctrl_enabled());
 
        w_atiadlsdk
                = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
                                                           "atiadlsdk"));
-#if !HAVE_LIBATIADL
-       gtk_widget_set_sensitive(GTK_WIDGET(w_atiadlsdk), 0);
-#endif
+       if (amd_is_supported()) {
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_atiadlsdk), FALSE);
+       } else {
+               gtk_widget_set_sensitive(GTK_WIDGET(w_atiadlsdk), 0);
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_atiadlsdk), TRUE);
+       }
+
        gtk_toggle_button_set_active(w_atiadlsdk,
                                     config_is_atiadlsdk_enabled());
 
        w_gtop2
                = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
                                                           "gtop2"));
-#if !HAVE_GTOP
-       gtk_widget_set_sensitive(GTK_WIDGET(w_gtop2), 0);
-#endif
+
+       if (gtop2_is_supported()) {
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_gtop2), FALSE);
+       } else {
+               gtk_widget_set_sensitive(GTK_WIDGET(w_gtop2), 0);
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_gtop2), TRUE);
+       }
+
        gtk_toggle_button_set_active(w_gtop2, config_is_gtop2_enabled());
 
        w_hddtemp
@@ -214,20 +258,32 @@ void ui_pref_dialog_run(struct ui_psensor *ui)
        w_libatasmart
                = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
                                                           "libatasmart"));
-#if !HAVE_ATASMART
-       gtk_widget_set_sensitive(GTK_WIDGET(w_libatasmart), 0);
-#endif
+
+       if (atasmart_is_supported()) {
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_libatasmart), FALSE);
+       } else {
+               gtk_widget_set_sensitive(GTK_WIDGET(w_libatasmart), 0);
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_libatasmart), TRUE);
+       }
+
        gtk_toggle_button_set_active(w_libatasmart,
                                     config_is_libatasmart_enabled());
 
        w_udisks2
                = GTK_TOGGLE_BUTTON(gtk_builder_get_object(builder,
                                                           "udisks2"));
-#if !HAVE_LIBUDISKS2
-       gtk_widget_set_sensitive(GTK_WIDGET(w_udisks2), 0);
-#endif
+
+       if (udisks2_is_supported()) {
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_udisks2), FALSE);
+       } else {
+               gtk_widget_set_sensitive(GTK_WIDGET(w_udisks2), 0);
+               gtk_widget_set_has_tooltip(GTK_WIDGET(w_udisks2), TRUE);
+       }
+
        gtk_toggle_button_set_active(w_udisks2, config_is_udisks2_enabled());
 
+       gtk_builder_connect_signals(builder, NULL);
+
        result = gtk_dialog_run(diag);
 
        if (result == GTK_RESPONSE_ACCEPT) {
@@ -262,9 +318,6 @@ void ui_pref_dialog_run(struct ui_psensor *ui)
                cfg->sensorlist_position
                        = gtk_combo_box_get_active(w_sensorlist_pos);
 
-               cfg->window_decoration_enabled =
-                       !gtk_toggle_button_get_active(w_hide_window_decoration);
-
                cfg->window_keep_below_enabled
                        = gtk_toggle_button_get_active(w_keep_window_below);
 
@@ -275,9 +328,6 @@ void ui_pref_dialog_run(struct ui_psensor *ui)
                        = !gtk_toggle_button_get_active
                        (w_enable_launcher_counter);
 
-               gtk_window_set_decorated(GTK_WINDOW(ui->main_window),
-                                        cfg->window_decoration_enabled);
-
                gtk_window_set_keep_below(GTK_WINDOW(ui->main_window),
                                          cfg->window_keep_below_enabled);