summaryrefslogtreecommitdiff
path: root/cpufreq
diff options
context:
space:
mode:
authorlukefromdc <[email protected]>2018-06-08 18:20:39 -0400
committerlukefromdc <[email protected]>2018-06-11 14:23:44 -0400
commit618ab266bc51aa7c7e880b8459f4389a12c3f21e (patch)
tree73eb7eca43e6bbc55f0b27f032a27f20a957326a /cpufreq
parent8bd11f81e05d8498c530e3951fa0f1c2b67a74b8 (diff)
downloadmate-applets-618ab266bc51aa7c7e880b8459f4389a12c3f21e.tar.bz2
mate-applets-618ab266bc51aa7c7e880b8459f4389a12c3f21e.tar.xz
Cpufreq: Refactor to remove more GTK2 leftovers
Diffstat (limited to 'cpufreq')
-rw-r--r--cpufreq/src/cpufreq-applet.c122
1 files changed, 10 insertions, 112 deletions
diff --git a/cpufreq/src/cpufreq-applet.c b/cpufreq/src/cpufreq-applet.c
index e9be2701..58cd64a6 100644
--- a/cpufreq/src/cpufreq-applet.c
+++ b/cpufreq/src/cpufreq-applet.c
@@ -64,10 +64,6 @@ struct _CPUFreqApplet {
GtkWidget *container;
cairo_surface_t *surfaces[5];
- gint max_label_width;
- gint max_perc_width;
- gint max_unit_width;
-
gboolean need_refresh;
CPUFreqPrefs *prefs;
@@ -305,63 +301,6 @@ get_max_text_width (GtkWidget *widget,
return logical_rect.width;
}
-static gint
-cpufreq_applet_get_max_label_width (CPUFreqApplet *applet)
-{
- GList *available_freqs;
- gint width = 0;
-
- if (applet->max_label_width > 0)
- return applet->max_label_width;
-
- if (!CPUFREQ_IS_MONITOR (applet->monitor))
- return 0;
-
- available_freqs = cpufreq_monitor_get_available_frequencies (applet->monitor);
- while (available_freqs) {
- gint label_width;
- const gchar *text;
- gchar *freq_text;
- gint freq;
-
- text = (const gchar *) available_freqs->data;
- freq = atoi (text);
-
- freq_text = cpufreq_utils_get_frequency_label (freq);
- label_width = get_max_text_width (applet->label, freq_text);
- width = MAX (width, label_width);
-
- g_free (freq_text);
-
- available_freqs = g_list_next (available_freqs);
- }
-
- applet->max_label_width = width;
-
- return width;
-}
-
-static gint
-cpufreq_applet_get_max_perc_width (CPUFreqApplet *applet)
-{
- if (applet->max_perc_width > 0)
- return applet->max_perc_width;
-
- applet->max_perc_width = get_max_text_width (applet->label, "100%");
- return applet->max_perc_width;
-}
-
-static gint
-cpufreq_applet_get_max_unit_width (CPUFreqApplet *applet)
-{
- if (applet->max_unit_width > 0)
- return applet->max_unit_width;
-
- applet->max_unit_width = MAX (get_max_text_width (applet->unit_label, "GHz"),
- get_max_text_width (applet->unit_label, "MHz"));
- return applet->max_unit_width;
-}
-
static void
cpufreq_applet_popup_position_menu (GtkMenu *menu,
int *x,
@@ -530,10 +469,6 @@ cpufreq_applet_style_updated (GtkWidget *widget)
applet = CPUFREQ_APPLET (widget);
- applet->max_label_width = 0;
- applet->max_unit_width = 0;
- applet->max_perc_width = 0;
-
cpufreq_applet_refresh (applet);
/*Reset label sizes to zero that have been held to maximum reached width*/
@@ -811,34 +746,6 @@ cpufreq_applet_update (CPUFreqApplet *applet, CPUFreqMonitor *monitor)
}
}
-static gint
-cpufreq_applet_get_widget_size (CPUFreqApplet *applet,
- GtkWidget *widget)
-{
- GtkRequisition req;
- gint size;
-
- if (!gtk_widget_get_visible (widget))
- return 0;
-
- gtk_widget_get_preferred_size (widget, &req, NULL);
-
- switch (applet->orient) {
- case MATE_PANEL_APPLET_ORIENT_LEFT:
- case MATE_PANEL_APPLET_ORIENT_RIGHT:
- size = req.width;
- break;
- case MATE_PANEL_APPLET_ORIENT_UP:
- case MATE_PANEL_APPLET_ORIENT_DOWN:
- size = req.height;
- break;
- default:
- g_assert_not_reached ();
- }
-
- return size;
-}
-
static void
cpufreq_applet_refresh (CPUFreqApplet *applet)
{
@@ -848,32 +755,23 @@ cpufreq_applet_refresh (CPUFreqApplet *applet)
gint size_step = 12;
gboolean horizontal;
gboolean do_unref = FALSE;
- GtkRequisition req;
panel_size = applet->size - 1; /* 1 pixel margin */
horizontal = (applet->orient == MATE_PANEL_APPLET_ORIENT_UP ||
applet->orient == MATE_PANEL_APPLET_ORIENT_DOWN);
- /* Zero out and reset the size of the label in case the theme is getting smaller */
- gtk_widget_set_size_request (GTK_WIDGET (applet->label), 0, 0);
- gtk_widget_get_preferred_size (GTK_WIDGET (applet->label),&req, NULL);
- gtk_widget_set_size_request (GTK_WIDGET (applet->label),req.width, req.height);
+
/* We want a fixed label size, the biggest */
- if (horizontal)
- label_size = cpufreq_applet_get_widget_size (applet, applet->label);
- else
- label_size = cpufreq_applet_get_max_label_width (applet);
- total_size += label_size;
-
- if (horizontal)
- unit_label_size = cpufreq_applet_get_widget_size (applet, applet->unit_label);
- else
- unit_label_size = cpufreq_applet_get_max_unit_width (applet);
- total_size += unit_label_size;
-
- pixmap_size = cpufreq_applet_get_widget_size (applet, applet->icon);
- total_size += pixmap_size;
+
+ gtk_widget_get_preferred_width(GTK_WIDGET(applet->label), &label_size, NULL);
+ total_size += label_size;
+
+ gtk_widget_get_preferred_width(GTK_WIDGET(applet->unit_label), &unit_label_size, NULL);
+ total_size += unit_label_size;
+
+ gtk_widget_get_preferred_width(GTK_WIDGET(applet->icon), &pixmap_size, NULL);
+ total_size += pixmap_size;
if (applet->box) {
do_unref = TRUE;