Skip to content

Commit

Permalink
gpm-prefs: fix memory leak
Browse files Browse the repository at this point in the history
In addition, it adds enumerations to access indexed arrays.
  • Loading branch information
rbuj committed Dec 8, 2021
1 parent 14ae269 commit a32c45a
Show file tree
Hide file tree
Showing 2 changed files with 104 additions and 69 deletions.
4 changes: 1 addition & 3 deletions src/gpm-prefs.c
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@ main (int argc, char **argv)
g_option_context_add_main_entries (context, options, GETTEXT_PACKAGE);
g_option_context_add_group (context, gtk_get_option_group (FALSE));
g_option_context_parse (context, &argc, &argv, NULL);
g_option_context_free (context);

gdk_init (&argc, &argv);
app = gtk_application_new("org.mate.PowerManager.Preferences", 0);
Expand All @@ -103,8 +104,5 @@ main (int argc, char **argv)

g_object_unref (app);

/* seems to not work...
g_option_context_free (context); */

return status;
}
169 changes: 103 additions & 66 deletions src/gpm-statistics.c
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,6 @@ static GtkBuilder *builder = NULL;
static GtkListStore *list_store_info = NULL;
static GtkListStore *list_store_devices = NULL;
gchar *current_device = NULL;
static const gchar *history_type;
static const gchar *stats_type;
static guint history_time;
static GSettings *settings;
static gfloat sigma_smoothing = 0.0f;
Expand All @@ -64,6 +62,18 @@ enum {
GPM_DEVICES_COLUMN_LAST
};

#define GPM_STATS_CHARGE_DATA_VALUE "charge-data"
#define GPM_STATS_CHARGE_ACCURACY_VALUE "charge-accuracy"
#define GPM_STATS_DISCHARGE_DATA_VALUE "discharge-data"
#define GPM_STATS_DISCHARGE_ACCURACY_VALUE "discharge-accuracy"

/* TRANSLATORS: what we've observed about the device */
#define GPM_STATS_CHARGE_DATA_TEXT "Charge profile"
#define GPM_STATS_DISCHARGE_DATA_TEXT "Discharge profile"
/* TRANSLATORS: how accurately we can predict the time remaining of the battery */
#define GPM_STATS_CHARGE_ACCURACY_TEXT "Charge accuracy"
#define GPM_STATS_DISCHARGE_ACCURACY_TEXT "Discharge accuracy"

#define GPM_HISTORY_RATE_TEXT _("Rate")
#define GPM_HISTORY_CHARGE_TEXT _("Charge")
#define GPM_HISTORY_TIME_FULL_TEXT _("Time to full")
Expand All @@ -86,17 +96,29 @@ enum {
#define GPM_HISTORY_DAY_VALUE 24*60*60
#define GPM_HISTORY_WEEK_VALUE 7*24*60*60

/* TRANSLATORS: what we've observed about the device */
#define GPM_STATS_CHARGE_DATA_TEXT _("Charge profile")
#define GPM_STATS_DISCHARGE_DATA_TEXT _("Discharge profile")
/* TRANSLATORS: how accurately we can predict the time remaining of the battery */
#define GPM_STATS_CHARGE_ACCURACY_TEXT _("Charge accuracy")
#define GPM_STATS_DISCHARGE_ACCURACY_TEXT _("Discharge accuracy")

#define GPM_STATS_CHARGE_DATA_VALUE "charge-data"
#define GPM_STATS_CHARGE_ACCURACY_VALUE "charge-accuracy"
#define GPM_STATS_DISCHARGE_DATA_VALUE "discharge-data"
#define GPM_STATS_DISCHARGE_ACCURACY_VALUE "discharge-accuracy"
enum stats_type_enum {
GPM_STATS_CHARGE_TYPE = 0,
GPM_STATS_DISCHARGE_TYPE,
GPM_STATS_CHARGE_ACCURACY_TYPE,
GPM_STATS_DISCHARGE_ACCURACY_TYPE,
GPM_STATS_LAST_TYPE
};
static enum stats_type_enum stats_type;

enum history_type_enum {
GPM_HISTORY_RATE_TYPE = 0,
GPM_HISTORY_CHARGE_TYPE,
GPM_HISTORY_TIME_FULL_TYPE,
GPM_HISTORY_TIME_EMPTY_TYPE,
GPM_HISTORY_LAST_TYPE
};
static enum history_type_enum history_type;
static const char *history_types [GPM_HISTORY_LAST_TYPE] = {
[GPM_HISTORY_RATE_TYPE] = GPM_HISTORY_RATE_VALUE,
[GPM_HISTORY_CHARGE_TYPE] = GPM_HISTORY_CHARGE_VALUE,
[GPM_HISTORY_TIME_FULL_TYPE] = GPM_HISTORY_TIME_FULL_VALUE,
[GPM_HISTORY_TIME_EMPTY_TYPE] = GPM_HISTORY_TIME_EMPTY_VALUE
};

/**
* gpm_stats_button_help_cb:
Expand Down Expand Up @@ -506,7 +528,7 @@ gpm_stats_update_info_page_history (UpDevice *device)
gint32 offset;

new = g_ptr_array_new_with_free_func ((GDestroyNotify) gpm_point_obj_free);
if (g_strcmp0 (history_type, GPM_HISTORY_CHARGE_VALUE) == 0) {
if (history_type == GPM_HISTORY_CHARGE_TYPE) {
g_object_set (graph_history,
"type-x", GPM_GRAPH_WIDGET_TYPE_TIME,
"type-y", GPM_GRAPH_WIDGET_TYPE_PERCENTAGE,
Expand All @@ -517,7 +539,7 @@ gpm_stats_update_info_page_history (UpDevice *device)
"start-y", 0,
"stop-y", 100,
NULL);
} else if (g_strcmp0 (history_type, GPM_HISTORY_RATE_VALUE) == 0) {
} else if (history_type == GPM_HISTORY_RATE_TYPE) {
g_object_set (graph_history,
"type-x", GPM_GRAPH_WIDGET_TYPE_TIME,
"type-y", GPM_GRAPH_WIDGET_TYPE_POWER,
Expand All @@ -538,7 +560,7 @@ gpm_stats_update_info_page_history (UpDevice *device)
}

widget = GTK_WIDGET (gtk_builder_get_object (builder, "label_history_nodata"));
array = up_device_get_history_sync (device, history_type, history_time, 150, NULL, NULL);
array = up_device_get_history_sync (device, history_types [history_type], history_time, 150, NULL, NULL);
if (array == NULL) {
/* show no data label and hide graph */
gtk_widget_hide (graph_history);
Expand Down Expand Up @@ -571,7 +593,7 @@ gpm_stats_update_info_page_history (UpDevice *device)
else if (up_history_item_get_state (item) == UP_DEVICE_STATE_PENDING_DISCHARGE)
point->color = egg_color_from_rgb (0, 0, 200);
else {
if (g_strcmp0 (history_type, GPM_HISTORY_RATE_VALUE) == 0)
if (history_type == GPM_HISTORY_RATE_TYPE)
point->color = egg_color_from_rgb (255, 255, 255);
else
point->color = egg_color_from_rgb (0, 255, 0);
Expand Down Expand Up @@ -613,16 +635,16 @@ gpm_stats_update_info_page_stats (UpDevice *device)
const gchar *type = NULL;

new = g_ptr_array_new_with_free_func ((GDestroyNotify) gpm_point_obj_free);
if (g_strcmp0 (stats_type, GPM_STATS_CHARGE_DATA_VALUE) == 0) {
if (stats_type == GPM_STATS_CHARGE_TYPE) {
type = "charging";
use_data = TRUE;
} else if (g_strcmp0 (stats_type, GPM_STATS_DISCHARGE_DATA_VALUE) == 0) {
} else if (stats_type == GPM_STATS_DISCHARGE_TYPE) {
type = "discharging";
use_data = TRUE;
} else if (g_strcmp0 (stats_type, GPM_STATS_CHARGE_ACCURACY_VALUE) == 0) {
} else if (stats_type == GPM_STATS_CHARGE_ACCURACY_TYPE) {
type = "charging";
use_data = FALSE;
} else if (g_strcmp0 (stats_type, GPM_STATS_DISCHARGE_ACCURACY_VALUE) == 0) {
} else if (stats_type == GPM_STATS_DISCHARGE_ACCURACY_TYPE) {
type = "discharging";
use_data = FALSE;
} else {
Expand Down Expand Up @@ -975,25 +997,25 @@ gpm_stats_history_type_combo_changed_cb (GtkWidget *widget, gpointer data)
active = gtk_combo_box_get_active (GTK_COMBO_BOX (widget));

if (active == 0) {
history_type = GPM_HISTORY_RATE_VALUE;
history_type = GPM_HISTORY_RATE_TYPE;
/* TRANSLATORS: this is the X axis on the graph */
axis_x = _("Time elapsed");
/* TRANSLATORS: this is the Y axis on the graph */
axis_y = _("Power");
} else if (active == 1) {
history_type = GPM_HISTORY_CHARGE_VALUE;
history_type = GPM_HISTORY_CHARGE_TYPE;
/* TRANSLATORS: this is the X axis on the graph */
axis_x = _("Time elapsed");
/* TRANSLATORS: this is the Y axis on the graph for the whole battery device */
axis_y = _("Cell charge");
} else if (active == 2) {
history_type = GPM_HISTORY_TIME_FULL_VALUE;
history_type = GPM_HISTORY_TIME_FULL_TYPE;
/* TRANSLATORS: this is the X axis on the graph */
axis_x = _("Time elapsed");
/* TRANSLATORS: this is the Y axis on the graph */
axis_y = _("Predicted time");
} else if (active == 3) {
history_type = GPM_HISTORY_TIME_EMPTY_VALUE;
history_type = GPM_HISTORY_TIME_EMPTY_TYPE;
/* TRANSLATORS: this is the X axis on the graph */
axis_x = _("Time elapsed");
/* TRANSLATORS: this is the Y axis on the graph */
Expand All @@ -1011,7 +1033,7 @@ gpm_stats_history_type_combo_changed_cb (GtkWidget *widget, gpointer data)
gpm_stats_button_update_ui ();

/* save to gsettings */
g_settings_set_string (settings, GPM_SETTINGS_INFO_HISTORY_TYPE, history_type);
g_settings_set_string (settings, GPM_SETTINGS_INFO_HISTORY_TYPE, history_types [history_type]);
}

/**
Expand All @@ -1023,29 +1045,35 @@ gpm_stats_type_combo_changed_cb (GtkWidget *widget, gpointer data)
guint active;
const gchar *axis_x = NULL;
const gchar *axis_y = NULL;
const char *stats_types [GPM_STATS_LAST_TYPE] = {
[GPM_STATS_CHARGE_TYPE] = GPM_STATS_CHARGE_DATA_VALUE,
[GPM_STATS_DISCHARGE_TYPE] = GPM_STATS_CHARGE_ACCURACY_VALUE,
[GPM_STATS_CHARGE_ACCURACY_TYPE] = GPM_STATS_DISCHARGE_DATA_VALUE,
[GPM_STATS_DISCHARGE_ACCURACY_TYPE] = GPM_STATS_DISCHARGE_ACCURACY_VALUE
};

active = gtk_combo_box_get_active (GTK_COMBO_BOX (widget));

if (active == 0) {
stats_type = GPM_STATS_CHARGE_DATA_VALUE;
stats_type = GPM_STATS_CHARGE_TYPE;
/* TRANSLATORS: this is the X axis on the graph for the whole battery device */
axis_x = _("Cell charge");
/* TRANSLATORS: this is the Y axis on the graph */
axis_y = _("Correction factor");
} else if (active == 1) {
stats_type = GPM_STATS_CHARGE_ACCURACY_VALUE;
stats_type = GPM_STATS_CHARGE_ACCURACY_TYPE;
/* TRANSLATORS: this is the X axis on the graph for the whole battery device */
axis_x = _("Cell charge");
/* TRANSLATORS: this is the Y axis on the graph */
axis_y = _("Prediction accuracy");
} else if (active == 2) {
stats_type = GPM_STATS_DISCHARGE_DATA_VALUE;
stats_type = GPM_STATS_DISCHARGE_TYPE;
/* TRANSLATORS: this is the X axis on the graph for the whole battery device */
axis_x = _("Cell charge");
/* TRANSLATORS: this is the Y axis on the graph */
axis_y = _("Correction factor");
} else if (active == 3) {
stats_type = GPM_STATS_DISCHARGE_ACCURACY_VALUE;
stats_type = GPM_STATS_DISCHARGE_ACCURACY_TYPE;
/* TRANSLATORS: this is the X axis on the graph for the whole battery device */
axis_x = _("Cell charge");
/* TRANSLATORS: this is the Y axis on the graph */
Expand All @@ -1063,7 +1091,7 @@ gpm_stats_type_combo_changed_cb (GtkWidget *widget, gpointer data)
gpm_stats_button_update_ui ();

/* save to gsettings */
g_settings_set_string (settings, GPM_SETTINGS_INFO_STATS_TYPE, stats_type);
g_settings_set_string (settings, GPM_SETTINGS_INFO_STATS_TYPE, stats_types[stats_type]);
}

/**
Expand Down Expand Up @@ -1335,61 +1363,70 @@ main (int argc, char *argv[])
gpm_stats_add_devices_columns (GTK_TREE_VIEW (widget));
gtk_tree_view_columns_autosize (GTK_TREE_VIEW (widget)); /* show */

char *history_type_temp = g_settings_get_string (settings, GPM_SETTINGS_INFO_HISTORY_TYPE);
if ((history_type_temp == NULL) || (strcmp (history_type_temp, GPM_HISTORY_CHARGE_VALUE) == 0)) {
history_type = GPM_HISTORY_CHARGE_VALUE;
} else if (strcmp (history_type_temp, GPM_HISTORY_RATE_VALUE) == 0) {
history_type = GPM_HISTORY_RATE_VALUE;
} else if (strcmp (history_type_temp, GPM_HISTORY_TIME_FULL_VALUE) == 0) {
history_type = GPM_HISTORY_TIME_FULL_VALUE;
} else if (strcmp (history_type_temp, GPM_HISTORY_TIME_EMPTY_VALUE) == 0) {
history_type = GPM_HISTORY_TIME_EMPTY_VALUE;
char *history_type_str = g_settings_get_string (settings, GPM_SETTINGS_INFO_HISTORY_TYPE);
if ((history_type_str == NULL) || (strcmp (history_type_str, GPM_HISTORY_CHARGE_VALUE) == 0)) {
history_type = GPM_HISTORY_CHARGE_TYPE;
} else if (strcmp (history_type_str, GPM_HISTORY_RATE_VALUE) == 0) {
history_type = GPM_HISTORY_RATE_TYPE;
} else if (strcmp (history_type_str, GPM_HISTORY_TIME_FULL_VALUE) == 0) {
history_type = GPM_HISTORY_TIME_FULL_TYPE;
} else if (strcmp (history_type_str, GPM_HISTORY_TIME_EMPTY_VALUE) == 0) {
history_type = GPM_HISTORY_TIME_EMPTY_TYPE;
} else {
g_assert_not_reached ();
history_type = GPM_HISTORY_CHARGE_TYPE;
}
g_free (history_type_temp);
g_free (history_type_str);

history_time = g_settings_get_int (settings, GPM_SETTINGS_INFO_HISTORY_TIME);
if (history_time == 0)
history_time = GPM_HISTORY_HOUR_VALUE;

char *stats_type_temp = g_settings_get_string (settings, GPM_SETTINGS_INFO_STATS_TYPE);
if ((stats_type_temp == NULL) || (strcmp (stats_type_temp, GPM_STATS_CHARGE_DATA_VALUE) == 0)) {
stats_type = GPM_STATS_CHARGE_DATA_VALUE;
} else if (strcmp (stats_type_temp, GPM_STATS_DISCHARGE_DATA_VALUE) == 0) {
stats_type = GPM_STATS_DISCHARGE_DATA_VALUE;
} else if (strcmp (stats_type_temp, GPM_STATS_CHARGE_ACCURACY_VALUE) == 0) {
stats_type = GPM_STATS_CHARGE_ACCURACY_VALUE;
} else if (strcmp (stats_type_temp, GPM_STATS_DISCHARGE_ACCURACY_VALUE) == 0) {
stats_type = GPM_STATS_DISCHARGE_ACCURACY_VALUE;
char *stats_type_str = g_settings_get_string (settings, GPM_SETTINGS_INFO_STATS_TYPE);
if ((stats_type_str == NULL) || (strcmp (stats_type_str, GPM_STATS_CHARGE_DATA_VALUE) == 0)) {
stats_type = GPM_STATS_CHARGE_TYPE;
} else if (strcmp (stats_type_str, GPM_STATS_DISCHARGE_DATA_VALUE) == 0) {
stats_type = GPM_STATS_DISCHARGE_TYPE;
} else if (strcmp (stats_type_str, GPM_STATS_CHARGE_ACCURACY_VALUE) == 0) {
stats_type = GPM_STATS_CHARGE_ACCURACY_TYPE;
} else if (strcmp (stats_type_str, GPM_STATS_DISCHARGE_ACCURACY_VALUE) == 0) {
stats_type = GPM_STATS_DISCHARGE_ACCURACY_TYPE;
} else {
g_assert_not_reached ();
stats_type = GPM_STATS_CHARGE_TYPE;
}
g_free (stats_type_temp);
g_free (stats_type_str);

const char *history_text [GPM_HISTORY_LAST_TYPE] = {
[GPM_HISTORY_RATE_TYPE] = GPM_HISTORY_RATE_TEXT,
[GPM_HISTORY_CHARGE_TYPE] = GPM_HISTORY_CHARGE_TEXT,
[GPM_HISTORY_TIME_FULL_TYPE] = GPM_HISTORY_TIME_FULL_TEXT,
[GPM_HISTORY_TIME_EMPTY_TYPE] = GPM_HISTORY_TIME_EMPTY_TEXT
};
widget = GTK_WIDGET (gtk_builder_get_object (builder, "combobox_history_type"));
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), GPM_HISTORY_RATE_TEXT);
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), GPM_HISTORY_CHARGE_TEXT);
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), GPM_HISTORY_TIME_FULL_TEXT);
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), GPM_HISTORY_TIME_EMPTY_TEXT);
if (g_strcmp0 (history_type, GPM_HISTORY_RATE_VALUE) == 0)
for (i = 0; i < GPM_HISTORY_LAST_TYPE; i++)
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), history_text[i]);
if (history_type == GPM_HISTORY_RATE_TYPE)
gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 0);
else
gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 1);
g_signal_connect (G_OBJECT (widget), "changed",
G_CALLBACK (gpm_stats_history_type_combo_changed_cb), NULL);

const char *stats_text [GPM_STATS_LAST_TYPE] = {
[GPM_STATS_CHARGE_TYPE] = GPM_STATS_CHARGE_DATA_TEXT,
[GPM_STATS_DISCHARGE_TYPE] = GPM_STATS_DISCHARGE_DATA_TEXT,
[GPM_STATS_CHARGE_ACCURACY_TYPE] = GPM_STATS_CHARGE_ACCURACY_TEXT,
[GPM_STATS_DISCHARGE_ACCURACY_TYPE] = GPM_STATS_DISCHARGE_ACCURACY_TEXT
};
widget = GTK_WIDGET (gtk_builder_get_object (builder, "combobox_stats_type"));
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), GPM_STATS_CHARGE_DATA_TEXT);
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), GPM_STATS_CHARGE_ACCURACY_TEXT);
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), GPM_STATS_DISCHARGE_DATA_TEXT);
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), GPM_STATS_DISCHARGE_ACCURACY_TEXT);
if (g_strcmp0 (stats_type, GPM_STATS_CHARGE_DATA_VALUE) == 0)
for (i = 0; i < GPM_STATS_LAST_TYPE; i++)
gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT (widget), _(stats_text[i]));
if (stats_type == GPM_STATS_CHARGE_TYPE)
gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 0);
else if (g_strcmp0 (stats_type, GPM_STATS_CHARGE_DATA_VALUE) == 0)
else if (stats_type == GPM_STATS_CHARGE_TYPE)
gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 1);
else if (g_strcmp0 (stats_type, GPM_STATS_CHARGE_DATA_VALUE) == 0)
else if (stats_type == GPM_STATS_CHARGE_TYPE)
gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 2);
else if (g_strcmp0 (stats_type, GPM_STATS_CHARGE_DATA_VALUE) == 0)
else if (stats_type == GPM_STATS_CHARGE_TYPE)
gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 0);
else
gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 3);
Expand Down

0 comments on commit a32c45a

Please sign in to comment.