New Temperature config dialog.

- Works on small resolutions.
 - Fixes issues wrt radio widgets (in old dialog they would not always work
correctly).



SVN revision: 47798
This commit is contained in:
Christopher Michael 2010-04-07 01:31:09 +00:00
parent 72a851477e
commit 98dbcf9403
1 changed files with 211 additions and 371 deletions

View File

@ -1,211 +1,61 @@
/*
* vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
*/
#include "e.h"
#include "e_mod_main.h"
/* celsius */
#define TEMP_LOW_LOW 32
#define TEMP_LOW_MID 43
#define TEMP_LOW_HIGH 55
#define TEMP_HIGH_LOW 43
#define TEMP_HIGH_MID 65
#define TEMP_HIGH_HIGH 93
#define FAR_2_CEL(x) ((x - 32) / 9.0) * 5.0
#define CEL_2_FAR(x) (x * 9.0 / 5.0) + 32
#define FAR_2_CEL(x) (x - 32) / 1.8
#define CEL_2_FAR(x) (x * 1.8) + 32
struct _E_Config_Dialog_Data
struct _E_Config_Dialog_Data
{
int poll_method;
int poll_interval;
struct
{
int interval;
} poll;
int unit_method;
Unit units;
int low_method, low_temp;
int high_method, high_temp;
struct
{
int low, high;
} temp;
int sensor;
Eina_List *sensors;
Evas_Object *o_high, *o_low;
Config_Face *inst;
};
/* Protos */
/* local function prototypes */
static void *_create_data(E_Config_Dialog *cfd);
static void _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
static Evas_Object *_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
static int _basic_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
static Evas_Object *_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
static int _advanced_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
static void _fill_data(E_Config_Dialog_Data *cfdata);
static void _fill_sensors(E_Config_Dialog_Data *cfdata, const char *name);
static void _free_data(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata);
static Evas_Object *_basic_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
static int _basic_apply(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
static void _cb_display_changed(void *data, Evas_Object *obj __UNUSED__);
void
void
config_temperature_module(Config_Face *inst)
{
E_Config_Dialog *cfd;
E_Config_Dialog_View *v;
char buf[PATH_MAX];
char buff[PATH_MAX];
v = E_NEW(E_Config_Dialog_View, 1);
v->create_cfdata = _create_data;
v->free_cfdata = _free_data;
v->basic.apply_cfdata = _basic_apply_data;
v->basic.create_widgets = _basic_create_widgets;
v->advanced.apply_cfdata = _advanced_apply_data;
v->advanced.create_widgets = _advanced_create_widgets;
v->basic.create_widgets = _basic_create;
v->basic.apply_cfdata = _basic_apply;
snprintf(buf, sizeof(buf), "%s/e-module-temperature.edj",
e_module_dir_get(inst->module));
cfd = e_config_dialog_new(e_container_current_get(e_manager_current_get()),
_("Temperature Settings"),
"E", "_e_mod_temperature_config_dialog",
buf, 0, v, inst);
inst->config_dialog = cfd;
}
static void
_fill_data(E_Config_Dialog_Data *cfdata)
{
double p;
int pi;
Eina_List *therms, *l;
char path[PATH_MAX], *name;
cfdata->units = cfdata->inst->units;
if (cfdata->inst->units == CELCIUS)
cfdata->unit_method = 0;
else
cfdata->unit_method = 1;
pi = cfdata->inst->poll_interval;
cfdata->poll_interval = pi;
if ((pi >= 1) && (pi <= 64))
cfdata->poll_method = 4; /* Fast */
else if ((pi > 64) && (pi <= 128))
cfdata->poll_method = 128; /* Normal */
else if ((pi > 128) && (pi <= 256))
cfdata->poll_method = 256; /* Slow */
else if (pi > 256)
cfdata->poll_method = 512; /* Very Slow */
p = cfdata->inst->low;
if (cfdata->units == FAHRENHEIT)
p = FAR_2_CEL(p - 1); /* -1 so the conversion doesn't make mid go hi */
cfdata->low_temp = p;
if ((p >= 0) && (p <= TEMP_LOW_LOW))
cfdata->low_method = TEMP_LOW_LOW;
else if ((p > TEMP_LOW_LOW) && (p <= TEMP_LOW_MID))
cfdata->low_method = TEMP_LOW_MID;
else if (p > TEMP_LOW_MID)
cfdata->low_method = TEMP_LOW_HIGH;
p = cfdata->inst->high;
if (cfdata->units == FAHRENHEIT)
p = FAR_2_CEL(p - 1);
cfdata->high_temp = p;
if ((p >= 0) && (p <= TEMP_HIGH_LOW))
cfdata->high_method = TEMP_HIGH_LOW;
else if ((p > TEMP_HIGH_LOW) && (p <= TEMP_HIGH_MID))
cfdata->high_method = TEMP_HIGH_MID;
else if (p > TEMP_HIGH_MID)
cfdata->high_method = TEMP_HIGH_HIGH;
cfdata->sensor = 0;
switch (cfdata->inst->sensor_type)
{
case SENSOR_TYPE_NONE:
case SENSOR_TYPE_FREEBSD:
case SENSOR_TYPE_OMNIBOOK:
case SENSOR_TYPE_LINUX_MACMINI:
case SENSOR_TYPE_LINUX_PBOOK:
case SENSOR_TYPE_LINUX_INTELCORETEMP:
break;
case SENSOR_TYPE_LINUX_I2C:
therms = temperature_get_bus_files("i2c");
if (therms)
{
EINA_LIST_FREE(therms, name)
{
if (ecore_file_exists(name))
{
int len;
sprintf(path, "%s", ecore_file_file_get(name));
len = strlen(path);
if (len > 6)
path[len - 6] = '\0';
cfdata->sensors = eina_list_append(cfdata->sensors, strdup(path));
/* TODO: Track down the user friendly names and display them instead.
* User friendly names are not available on the system, lm-sensors
* contains a database in /etc/sensors.conf, but the format may change,
* so the best way to use that database is thru libsensors, but we
* don't want to add any more library dependencies.
*/
}
free(name);
}
}
EINA_LIST_FOREACH(cfdata->sensors, l, name)
{
if (!strcmp(cfdata->inst->sensor_name, name))
break;
cfdata->sensor++;
}
break;
case SENSOR_TYPE_LINUX_PCI:
therms = temperature_get_bus_files("pci");
if (therms)
{
EINA_LIST_FREE(therms, name)
{
if (ecore_file_exists(name))
{
int len;
sprintf(path, "%s", ecore_file_file_get(name));
len = strlen(path);
if (len > 6)
path[len - 6] = '\0';
cfdata->sensors = eina_list_append(cfdata->sensors, strdup(path));
/* TODO: Track down the user friendly names and display them instead.
* User friendly names are not available on the system, lm-sensors
* contains a database in /etc/sensors.conf, but the format may change,
* so the best way to use that database is thru libsensors, but we
* don't want to add any more library dependencies.
*/
}
free(name);
}
}
EINA_LIST_FOREACH(cfdata->sensors, l, name)
{
if (!strcmp(cfdata->inst->sensor_name, name))
break;
cfdata->sensor++;
}
break;
case SENSOR_TYPE_LINUX_ACPI:
therms = ecore_file_ls("/proc/acpi/thermal_zone");
if (therms)
{
int n = 0;
EINA_LIST_FREE(therms, name)
{
cfdata->sensors = eina_list_append(cfdata->sensors, name);
if (!strcmp(cfdata->inst->sensor_name, name))
cfdata->sensor = n;
n++;
}
}
break;
}
snprintf(buff, sizeof(buff),
"%s/e-module-temperature.edj", inst->module->dir);
inst->config_dialog =
e_config_dialog_new(e_container_current_get(e_manager_current_get()),
_("Temperature Settings"), "E",
"_e_mod_temperature_config_dialog", buff, 0, v, inst);
}
/* local function prototypes */
static void *
_create_data(E_Config_Dialog *cfd)
{
@ -213,231 +63,221 @@ _create_data(E_Config_Dialog *cfd)
cfdata = E_NEW(E_Config_Dialog_Data, 1);
cfdata->inst = cfd->data;
cfdata->sensors = NULL;
_fill_data(cfdata);
return cfdata;
}
static void
_free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
static void
_fill_data(E_Config_Dialog_Data *cfdata)
{
cfdata->unit_method = cfdata->inst->units;
cfdata->poll.interval = cfdata->inst->poll_interval;
cfdata->temp.low = cfdata->inst->low;
cfdata->temp.high = cfdata->inst->high;
cfdata->sensor = 0;
switch (cfdata->inst->sensor_type)
{
case SENSOR_TYPE_NONE:
case SENSOR_TYPE_FREEBSD:
case SENSOR_TYPE_OMNIBOOK:
case SENSOR_TYPE_LINUX_MACMINI:
case SENSOR_TYPE_LINUX_PBOOK:
case SENSOR_TYPE_LINUX_INTELCORETEMP:
break;
case SENSOR_TYPE_LINUX_I2C:
_fill_sensors(cfdata, "i2c");
break;
case SENSOR_TYPE_LINUX_PCI:
_fill_sensors(cfdata, "pci");
break;
case SENSOR_TYPE_LINUX_ACPI:
{
Eina_List *l;
if (l = ecore_file_ls("/proc/acpi/thermal_zone"))
{
char *name;
int n = 0;
EINA_LIST_FREE(l, name)
{
cfdata->sensors =
eina_list_append(cfdata->sensors, name);
if (!strcmp(cfdata->inst->sensor_name, name))
cfdata->sensor = n;
n++;
}
}
break;
}
default:
break;
}
}
static void
_fill_sensors(E_Config_Dialog_Data *cfdata, const char *name)
{
Eina_List *therms, *l;
char *n;
if (!name) return;
if (therms = temperature_get_bus_files(name))
{
char path[PATH_MAX];
EINA_LIST_FREE(therms, n)
{
if (ecore_file_exists(n))
{
int len;
sprintf(path, "%s", ecore_file_file_get(n));
len = strlen(path);
if (len > 6) path[len - 6] = '\0';
cfdata->sensors =
eina_list_append(cfdata->sensors, strdup(path));
}
free(n);
}
}
EINA_LIST_FOREACH(cfdata->sensors, l, n)
{
if (!strcmp(cfdata->inst->sensor_name, n)) break;
cfdata->sensor++;
}
}
static void
_free_data(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata)
{
char *sensor;
cfdata->inst->config_dialog = NULL;
EINA_LIST_FREE(cfdata->sensors, sensor)
free(sensor);
free(cfdata);
E_FREE(cfdata);
}
static Evas_Object *
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
_basic_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
{
Evas_Object *o, *of, *ob;
Evas_Object *otb, *ol, *ow;
E_Radio_Group *rg;
o = e_widget_list_add(evas, 0, 0);
of = e_widget_framelist_add(evas, _("Display Units"), 0);
otb = e_widget_toolbook_add(evas, 24, 24);
if (cfdata->sensors)
{
Eina_List *l;
char *name;
int n = 0;
ol = e_widget_list_add(evas, 0, 0);
rg = e_widget_radio_group_new(&(cfdata->sensor));
EINA_LIST_FOREACH(cfdata->sensors, l, name)
{
ow = e_widget_radio_add(evas, _(name), n, rg);
e_widget_list_object_append(ol, ow, 1, 0, 0.5);
n++;
}
e_widget_toolbook_page_append(otb, NULL, _("Sensors"), ol,
1, 0, 1, 0, 0.5, 0.0);
}
ol = e_widget_list_add(evas, 0, 0);
rg = e_widget_radio_group_new(&(cfdata->unit_method));
ob = e_widget_radio_add(evas, _("Celsius"), 0, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Fahrenheit"), 1, rg);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
ow = e_widget_radio_add(evas, _("Celcius"), CELCIUS, rg);
e_widget_on_change_hook_set(ow, _cb_display_changed, cfdata);
e_widget_list_object_append(ol, ow, 1, 1, 0.5);
ow = e_widget_radio_add(evas, _("Fahrenheit"), FAHRENHEIT, rg);
e_widget_on_change_hook_set(ow, _cb_display_changed, cfdata);
e_widget_list_object_append(ol, ow, 1, 1, 0.5);
e_widget_toolbook_page_append(otb, NULL, _("Display Units"), ol,
0, 0, 0, 0, 0.5, 0.0);
of = e_widget_framelist_add(evas, _("Check Interval"), 0);
rg = e_widget_radio_group_new(&(cfdata->poll_method));
ob = e_widget_radio_add(evas, _("Fast"), 4, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Normal"), 128, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Slow"), 256, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Very Slow"), 512, rg);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
ol = e_widget_list_add(evas, 0, 0);
ow = e_widget_slider_add(evas, 1, 0, _("%1.0f ticks"), 1, 1024, 4, 0,
NULL, &(cfdata->poll.interval), 150);
e_widget_list_object_append(ol, ow, 1, 1, 0.5);
e_widget_toolbook_page_append(otb, NULL, _("Check Interval"), ol,
1, 0, 1, 0, 0.5, 0.0);
if (cfdata->units == FAHRENHEIT)
{
of = e_widget_framelist_add(evas, _("High Temperature"), 0);
rg = e_widget_radio_group_new(&(cfdata->high_method));
ob = e_widget_radio_add(evas, _("200 F"), TEMP_HIGH_HIGH, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("150 F"), TEMP_HIGH_MID, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("110 F"), TEMP_HIGH_LOW, rg);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
of = e_widget_framelist_add(evas, _("Low Temperature"), 0);
rg = e_widget_radio_group_new(&(cfdata->low_method));
ob = e_widget_radio_add(evas, _("130 F"), TEMP_LOW_HIGH, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("110 F"), TEMP_LOW_MID, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("90 F"), TEMP_LOW_LOW, rg);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
}
ol = e_widget_list_add(evas, 0, 0);
ow = e_widget_label_add(evas, _("High Temperature"));
e_widget_list_object_append(ol, ow, 1, 1, 0.5);
if (cfdata->unit_method == FAHRENHEIT)
cfdata->o_high =
e_widget_slider_add(evas, 1, 0, _("%1.0f F"), 0, 230, 5, 0,
NULL, &(cfdata->temp.high), 150);
else
{
of = e_widget_framelist_add(evas, _("High Temperature"), 0);
rg = e_widget_radio_group_new(&(cfdata->high_method));
cfdata->o_high =
e_widget_slider_add(evas, 1, 0, _("%1.0f C"), 0, 110, 5, 0,
NULL, &(cfdata->temp.high), 150);
e_widget_list_object_append(ol, cfdata->o_high, 1, 1, 0.5);
ob = e_widget_radio_add(evas, _("93 C"), TEMP_HIGH_HIGH, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("65 C"), TEMP_HIGH_MID, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("43 C"), TEMP_HIGH_LOW, rg);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
ow = e_widget_label_add(evas, _("Low Temperature"));
e_widget_list_object_append(ol, ow, 1, 1, 0.5);
if (cfdata->unit_method == FAHRENHEIT)
cfdata->o_low =
e_widget_slider_add(evas, 1, 0, _("%1.0f F"), 0, 200, 5, 0,
NULL, &(cfdata->temp.low), 150);
else
cfdata->o_low =
e_widget_slider_add(evas, 1, 0, _("%1.0f C"), 0, 95, 5, 0,
NULL, &(cfdata->temp.low), 150);
e_widget_list_object_append(ol, cfdata->o_low, 1, 1, 0.5);
of = e_widget_framelist_add(evas, _("Low Temperature"), 0);
rg = e_widget_radio_group_new(&(cfdata->low_method));
e_widget_toolbook_page_append(otb, NULL, _("Temperatures"), ol,
1, 0, 1, 0, 0.5, 0.0);
ob = e_widget_radio_add(evas, _("55 C"), TEMP_LOW_HIGH, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("43 C"), TEMP_LOW_MID, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("32 C"), TEMP_LOW_LOW, rg);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
}
return o;
e_widget_toolbook_page_show(otb, 0);
return otb;
}
static int
_basic_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
static int
_basic_apply(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
{
if (cfdata->unit_method == 0)
cfdata->inst->units = CELCIUS;
else
cfdata->inst->units = FAHRENHEIT;
cfdata->inst->poll_interval = cfdata->poll_method;
if (cfdata->inst->units == FAHRENHEIT)
{
cfdata->inst->low = CEL_2_FAR(cfdata->low_method);
cfdata->inst->high = CEL_2_FAR(cfdata->high_method);
}
else
{
cfdata->inst->low = cfdata->low_method;
cfdata->inst->high = cfdata->high_method;
}
temperature_face_update_config(cfdata->inst);
cfdata->inst->poll_interval = cfdata->poll.interval;
cfdata->inst->units = cfdata->unit_method;
cfdata->inst->low = cfdata->temp.low;
cfdata->inst->high = cfdata->temp.high;
eina_stringshare_replace(&cfdata->inst->sensor_name,
eina_list_nth(cfdata->sensors, cfdata->sensor));
e_config_save_queue();
temperature_face_update_config(cfdata->inst);
return 1;
}
static Evas_Object *
_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
static void
_cb_display_changed(void *data, Evas_Object *obj __UNUSED__)
{
Evas_Object *o, *of, *ob;
E_Radio_Group *rg;
Eina_List *l;
E_Config_Dialog_Data *cfdata;
int val;
o = e_widget_list_add(evas, 0, 0);
of = e_widget_framelist_add(evas, _("Display Units"), 0);
rg = e_widget_radio_group_new(&(cfdata->unit_method));
ob = e_widget_radio_add(evas, _("Celsius"), 0, rg);
e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Fahrenheit"), 1, rg);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
if (cfdata->sensors)
if (!(cfdata = data)) return;
if (cfdata->unit_method == FAHRENHEIT)
{
/* TODO: Notify user which thermal system is in use */
/* TODO: Let the user choose the wanted thermal system */
char *name;
int n = 0;
of = e_widget_framelist_add(evas, _("Sensors"), 0);
rg = e_widget_radio_group_new(&(cfdata->sensor));
EINA_LIST_FOREACH(cfdata->sensors, l, name)
{
ob = e_widget_radio_add(evas, _(name), n, rg);
e_widget_framelist_object_append(of, ob);
n++;
}
e_widget_list_object_append(o, of, 1, 1, 0.5);
}
of = e_widget_framelist_add(evas, _("Check Interval"), 0);
ob = e_widget_slider_add(evas, 1, 0, _("%1.0f ticks"), 1, 1024, 4, 0, NULL, &(cfdata->poll_interval), 200);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
if (cfdata->units == FAHRENHEIT)
{
/* round-off to closest 5 */
if (cfdata->high_temp % 5 > 3)
cfdata->high_temp += 5 - (cfdata->high_temp % 5);
else
cfdata->high_temp -= (cfdata->high_temp % 5);
if (cfdata->low_temp % 5 > 3)
cfdata->low_temp += 5 - (cfdata->low_temp % 5);
else
cfdata->low_temp -= (cfdata->low_temp % 5);
of = e_widget_framelist_add(evas, _("High Temperature"), 0);
ob = e_widget_slider_add(evas, 1, 0, _("%1.0f F"), 0, 230, 5, 0, NULL, &(cfdata->high_temp), 200);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
of = e_widget_framelist_add(evas, _("Low Temperature"), 0);
ob = e_widget_slider_add(evas, 1, 0, _("%1.0f F"), 0, 200, 5, 0, NULL, &(cfdata->low_temp), 200);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
e_widget_slider_value_range_set(cfdata->o_low, 0, 200);
e_widget_slider_value_range_set(cfdata->o_high, 0, 230);
e_widget_slider_value_int_get(cfdata->o_low, &val);
e_widget_slider_value_int_set(cfdata->o_low, CEL_2_FAR(val));
e_widget_slider_value_int_get(cfdata->o_high, &val);
e_widget_slider_value_int_set(cfdata->o_high, CEL_2_FAR(val));
e_widget_slider_value_format_display_set(cfdata->o_low, _("%1.0f F"));
e_widget_slider_value_format_display_set(cfdata->o_high, _("%1.0f F"));
}
else
{
of = e_widget_framelist_add(evas, _("High Temperature"), 0);
ob = e_widget_slider_add(evas, 1, 0, _("%1.0f C"), 0, 110, 1, 0, NULL, &(cfdata->high_temp), 200);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
of = e_widget_framelist_add(evas, _("Low Temperature"), 0);
ob = e_widget_slider_add(evas, 1, 0, _("%1.0f C"), 0, 95, 1, 0, NULL, &(cfdata->low_temp), 200);
e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5);
}
return o;
}
static int
_advanced_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
{
if (cfdata->unit_method != cfdata->inst->units)
{
if (cfdata->unit_method == 0)
{
cfdata->high_temp = FAR_2_CEL(cfdata->high_temp);
cfdata->low_temp = FAR_2_CEL(cfdata->low_temp);
}
else
{
cfdata->high_temp = CEL_2_FAR(cfdata->high_temp);
cfdata->low_temp = CEL_2_FAR(cfdata->low_temp);
}
e_widget_slider_value_range_set(cfdata->o_low, 0, 95);
e_widget_slider_value_range_set(cfdata->o_high, 0, 110);
e_widget_slider_value_int_get(cfdata->o_low, &val);
e_widget_slider_value_int_set(cfdata->o_low, FAR_2_CEL(val));
e_widget_slider_value_int_get(cfdata->o_high, &val);
e_widget_slider_value_int_set(cfdata->o_high, FAR_2_CEL(val));
e_widget_slider_value_format_display_set(cfdata->o_low, _("%1.0f C"));
e_widget_slider_value_format_display_set(cfdata->o_high, _("%1.0f C"));
}
if (cfdata->unit_method == 0)
cfdata->inst->units = CELCIUS;
else
cfdata->inst->units = FAHRENHEIT;
cfdata->inst->poll_interval = cfdata->poll_interval;
cfdata->inst->low = cfdata->low_temp;
cfdata->inst->high = cfdata->high_temp;
if (cfdata->inst->sensor_name)
eina_stringshare_del(cfdata->inst->sensor_name);
cfdata->inst->sensor_name =
eina_stringshare_add(eina_list_nth(cfdata->sensors, cfdata->sensor));
temperature_face_update_config(cfdata->inst);
e_config_save_queue();
return 1;
}