Efl.Ui.Format: implement generic format_string function

This generic format_string would be used in slider,progressbar
and other widgets.This default function handles INT
and DOUBLE eina value types for now.

Ref T6204
This commit is contained in:
Amitesh Singh 2017-10-25 19:25:14 +09:00
parent b358fc4b69
commit 5298cb59d2
7 changed files with 123 additions and 100 deletions

View File

@ -129,6 +129,7 @@ lib/efl/interfaces/efl_io_buffer.c \
lib/efl/interfaces/efl_io_queue.c \ lib/efl/interfaces/efl_io_queue.c \
lib/efl/interfaces/efl_observer.c \ lib/efl/interfaces/efl_observer.c \
lib/efl/interfaces/efl_file.c \ lib/efl/interfaces/efl_file.c \
lib/efl/interfaces/efl_ui_format.c \
lib/efl/interfaces/efl_text_markup_util.c \ lib/efl/interfaces/efl_text_markup_util.c \
$(NULL) $(NULL)

View File

@ -68,7 +68,6 @@
#include "interfaces/efl_ui_scrollable.eo.c" #include "interfaces/efl_ui_scrollable.eo.c"
#include "interfaces/efl_ui_selectable.eo.c" #include "interfaces/efl_ui_selectable.eo.c"
#include "interfaces/efl_ui_zoom.eo.c" #include "interfaces/efl_ui_zoom.eo.c"
#include "interfaces/efl_ui_format.eo.c"
EAPI void EAPI void
__efl_internal_init(void) __efl_internal_init(void)

View File

@ -0,0 +1,63 @@
#include "config.h"
#include "Efl.h"
typedef struct
{
const char *template;
} Efl_Ui_Format_Data;
static void
_default_format_cb(void *data, Eina_Strbuf *str, const Eina_Value value)
{
const Eina_Value_Type *type = eina_value_type_get(&value);
Efl_Ui_Format_Data *sd = data;
if (type == EINA_VALUE_TYPE_DOUBLE)
{
double v;
eina_value_get(&value, &v);
eina_strbuf_append_printf(str, sd->template, v);
}
else if (type == EINA_VALUE_TYPE_INT)
{
int v;
eina_value_get(&value, &v);
eina_strbuf_append_printf(str, sd->template, v);
}
//XXX: handle other types e.g. struct tm
else
{
char *v = eina_value_to_string(&value);
eina_strbuf_append_printf(str, "%s", v);
free(v);
}
}
static void
_default_format_free_cb(void *data)
{
Efl_Ui_Format_Data *sd = data;
if (sd->template)
{
eina_stringshare_del(sd->template);
sd->template = NULL;
}
}
EOLIAN static void
_efl_ui_format_format_string_set(Eo *obj, Efl_Ui_Format_Data *sd, const char *template)
{
if (!template) return;
eina_stringshare_replace(&sd->template, template);
efl_ui_format_cb_set(obj, sd, _default_format_cb, _default_format_free_cb);
}
EOLIAN static const char *
_efl_ui_format_format_string_get(Eo *obj EINA_UNUSED, Efl_Ui_Format_Data *sd)
{
return sd->template;
}
#include "interfaces/efl_ui_format.eo.c"

View File

@ -8,12 +8,12 @@ function Efl.Ui.Format_Func_Cb {
} }
}; };
interface Efl.Ui.Format mixin Efl.Ui.Format
{ {
[[interface class for format_func]] [[interface class for format_func]]
methods { methods {
@property format_cb { @property format_cb {
set { set @pure_virtual {
[[Set the format function pointer to format the string. [[Set the format function pointer to format the string.
]] ]]
} }

View File

@ -221,39 +221,21 @@ _units_set(Evas_Object *obj)
Eina_Value val; Eina_Value val;
eina_value_setup(&val, EINA_VALUE_TYPE_DOUBLE); eina_value_setup(&val, EINA_VALUE_TYPE_DOUBLE);
eina_value_set(&val, sd->val);
eina_strbuf_reset(sd->format_strbuf); eina_strbuf_reset(sd->format_strbuf);
sd->format_cb(sd->format_cb_data, sd->format_strbuf, val);
elm_layout_text_set(obj, "elm.units", eina_strbuf_string_get(sd->format_strbuf));
if (!sd->units_show)
{
elm_layout_signal_emit(obj, "elm,state,units,visible", "elm");
sd->units_show = EINA_TRUE;
}
else
{
elm_layout_signal_emit(obj, "elm,state,units,hidden", "elm");
sd->units_show = EINA_FALSE;
}
}
else if (sd->units)
{
char buf[1024];
if (!sd->intvl_enable) if (!sd->intvl_enable)
snprintf(buf, sizeof(buf), sd->units, sd->val); eina_value_set(&val, sd->val);
else else
{ {
double v1, v2; double v1, v2;
elm_slider_range_get(obj, &v1, &v2); elm_slider_range_get(obj, &v1, &v2);
snprintf(buf, sizeof(buf), sd->units, v2 - v1); eina_value_set(&val, v2 - v1);
} }
elm_layout_text_set(obj, "elm.units", buf); sd->format_cb(sd->format_cb_data, sd->format_strbuf, val);
elm_layout_text_set(obj, "elm.units", eina_strbuf_string_get(sd->format_strbuf));
if (!sd->units_show) if (!sd->units_show)
{ {
elm_layout_signal_emit(obj, "elm,state,units,visible", "elm"); elm_layout_signal_emit(obj, "elm,state,units,visible", "elm");
@ -1031,35 +1013,26 @@ _spacer_up_cb(void *data,
static void static void
_min_max_set(Evas_Object *obj) _min_max_set(Evas_Object *obj)
{ {
char *buf_min = NULL;
char *buf_max = NULL;
EFL_UI_SLIDER_DATA_GET(obj, sd); EFL_UI_SLIDER_DATA_GET(obj, sd);
Eina_Strbuf *str;
Eina_Value val;
if (sd->units_format_func) if (!sd->format_cb) return;
{ eina_value_setup(&val, EINA_VALUE_TYPE_DOUBLE);
buf_min = sd->units_format_func(sd->val_min);
buf_max = sd->units_format_func(sd->val_max);
}
else if (sd->units)
{
int length = eina_stringshare_strlen(sd->units);
buf_min = alloca(length + 128); str = eina_strbuf_new();
buf_max = alloca(length + 128);
snprintf((char *)buf_min, length + 128, sd->units, sd->val_min); eina_value_set(&val, sd->val_max);
snprintf((char *)buf_max, length + 128, sd->units, sd->val_max); sd->format_cb(sd->format_cb_data, str, val);
} elm_layout_text_set(obj, "elm.units.min", eina_strbuf_string_get(str));
elm_layout_text_set(obj, "elm.units.min", buf_min); eina_strbuf_reset(str);
elm_layout_text_set(obj, "elm.units.max", buf_max);
if (sd->units_format_func && sd->units_format_free) eina_value_set(&val, sd->val_min);
{ sd->format_cb(sd->format_cb_data, str, val);
sd->units_format_free(buf_min); elm_layout_text_set(obj, "elm.units.max", eina_strbuf_string_get(str));
sd->units_format_free(buf_max);
} eina_strbuf_free(str);
} }
EOLIAN static void EOLIAN static void
@ -1196,7 +1169,6 @@ EOLIAN static void
_efl_ui_slider_efl_canvas_group_group_del(Eo *obj, Efl_Ui_Slider_Data *sd) _efl_ui_slider_efl_canvas_group_group_del(Eo *obj, Efl_Ui_Slider_Data *sd)
{ {
eina_stringshare_del(sd->indicator); eina_stringshare_del(sd->indicator);
eina_stringshare_del(sd->units);
ecore_timer_del(sd->delay); ecore_timer_del(sd->delay);
ecore_timer_del(sd->wheel_indicator_timer); ecore_timer_del(sd->wheel_indicator_timer);
evas_object_del(sd->popup); evas_object_del(sd->popup);
@ -1431,42 +1403,11 @@ _efl_ui_slider_efl_access_value_increment_get(Eo *obj EINA_UNUSED, Efl_Ui_Slider
return sd->step; return sd->step;
} }
EOLIAN static void
_efl_ui_slider_efl_ui_format_format_string_set(Eo *obj, Efl_Ui_Slider_Data *sd, const char *units)
{
ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
eina_stringshare_replace(&sd->units, units);
if (units)
{
elm_layout_signal_emit(obj, "elm,state,units,visible", "elm");
edje_object_message_signal_process(wd->resize_obj);
if (sd->popup)
edje_object_signal_emit(sd->popup, "elm,state,units,visible", "elm");
if (sd->popup2)
edje_object_signal_emit(sd->popup2, "elm,state,units,visible", "elm");
}
else
{
elm_layout_signal_emit(obj, "elm,state,units,hidden", "elm");
edje_object_message_signal_process(wd->resize_obj);
if (sd->popup)
edje_object_signal_emit(sd->popup, "elm,state,units,hidden", "elm");
if (sd->popup2)
edje_object_signal_emit(sd->popup2, "elm,state,units,hidden", "elm");
}
evas_object_smart_changed(obj);
}
EOLIAN static const char *
_efl_ui_slider_efl_ui_format_format_string_get(Eo *obj EINA_UNUSED, Efl_Ui_Slider_Data *sd)
{
return sd->units;
}
EOLIAN static void EOLIAN static void
_efl_ui_slider_efl_ui_format_format_cb_set(Eo *obj, Efl_Ui_Slider_Data *sd, void *func_data, Efl_Ui_Format_Func_Cb func, Eina_Free_Cb func_free_cb) _efl_ui_slider_efl_ui_format_format_cb_set(Eo *obj, Efl_Ui_Slider_Data *sd, void *func_data, Efl_Ui_Format_Func_Cb func, Eina_Free_Cb func_free_cb)
{ {
ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
if (sd->format_cb_data == func_data && sd->format_cb == func) if (sd->format_cb_data == func_data && sd->format_cb == func)
return; return;
@ -1478,6 +1419,13 @@ _efl_ui_slider_efl_ui_format_format_cb_set(Eo *obj, Efl_Ui_Slider_Data *sd, void
sd->format_free_cb = func_free_cb; sd->format_free_cb = func_free_cb;
if (!sd->format_strbuf) sd->format_strbuf = eina_strbuf_new(); if (!sd->format_strbuf) sd->format_strbuf = eina_strbuf_new();
elm_layout_signal_emit(obj, "elm,state,units,visible", "elm");
edje_object_message_signal_process(wd->resize_obj);
if (sd->popup)
edje_object_signal_emit(sd->popup, "elm,state,units,visible", "elm");
if (sd->popup2)
edje_object_signal_emit(sd->popup2, "elm,state,units,visible", "elm");
efl_canvas_group_change(obj); efl_canvas_group_change(obj);
} }
@ -1614,29 +1562,46 @@ elm_slider_inverted_get(const Evas_Object *obj)
return _is_inverted(dir); return _is_inverted(dir);
} }
static void typedef struct
_format_legacy_to_format_eo_cb(void *data, Eina_Strbuf *str, const Eina_Value value EINA_UNUSED)
{ {
Efl_Ui_Slider_Data *sd = data; slider_func_type format_cb;
char *buf; slider_freefunc_type format_free_cb;
} Slider_Format_Wrapper_Data;
buf = sd->units_format_func(sd->val); static void
_format_legacy_to_format_eo_cb(void *data, Eina_Strbuf *str, const Eina_Value value)
{
Slider_Format_Wrapper_Data *sfwd = data;
char *buf = NULL;
double val = 0;
const Eina_Value_Type *type = eina_value_type_get(&value);
if (type == EINA_VALUE_TYPE_DOUBLE)
eina_value_get(&value, &val);
if (sfwd->format_cb)
buf = sfwd->format_cb(val);
if (buf) if (buf)
eina_strbuf_append(str, buf); eina_strbuf_append(str, buf);
if (sd->units_format_free) sd->units_format_free(buf); if (sfwd->format_free_cb) sfwd->format_free_cb(buf);
}
static void
_format_legacy_to_format_eo_free_cb(void *data)
{
Slider_Format_Wrapper_Data *sfwd = data;
free(sfwd);
} }
EAPI void EAPI void
elm_slider_units_format_function_set(Evas_Object *obj, slider_func_type func, slider_freefunc_type free_func) elm_slider_units_format_function_set(Evas_Object *obj, slider_func_type func, slider_freefunc_type free_func)
{ {
EFL_UI_SLIDER_DATA_GET_OR_RETURN(obj, sd); Slider_Format_Wrapper_Data *sfwd = malloc(sizeof(Slider_Format_Wrapper_Data));
sd->units_format_func = func; sfwd->format_cb = func;
sd->units_format_free = free_func; sfwd->format_free_cb = free_func;
efl_ui_format_cb_set(obj, sd, _format_legacy_to_format_eo_cb, NULL); efl_ui_format_cb_set(obj, sfwd, _format_legacy_to_format_eo_cb, _format_legacy_to_format_eo_free_cb);
evas_object_smart_changed(obj);
} }
EAPI void EAPI void

View File

@ -128,7 +128,6 @@ class Efl.Ui.Slider (Efl.Ui.Layout, Efl.Ui.Range, Efl.Ui.Direction,
Elm.Interface.Atspi_Widget_Action.elm_actions { get; } Elm.Interface.Atspi_Widget_Action.elm_actions { get; }
Efl.Text.text { get; set; } Efl.Text.text { get; set; }
Efl.Text.Markup.markup { get; set; } Efl.Text.Markup.markup { get; set; }
Efl.Ui.Format.format_string { get; set; }
Efl.Ui.Format.format_cb { set; } Efl.Ui.Format.format_cb { set; }
Efl.Ui.Translatable.translatable_text { get; set; } Efl.Ui.Translatable.translatable_text { get; set; }
} }

View File

@ -29,15 +29,11 @@ struct _Efl_Ui_Slider_Data
Evas_Object *spacer, *popup, *popup2, *track, *track2; Evas_Object *spacer, *popup, *popup2, *track, *track2;
Ecore_Timer *delay; Ecore_Timer *delay;
const char *units;
const char *indicator; const char *indicator;
char *(*indicator_format_func)(double val); char *(*indicator_format_func)(double val);
void (*indicator_format_free)(char *str); void (*indicator_format_free)(char *str);
char *(*units_format_func)(double val);
void (*units_format_free)(char *str);
double val, val_min, val_max, val2, step; double val, val_min, val_max, val2, step;
Ecore_Timer *wheel_indicator_timer; Ecore_Timer *wheel_indicator_timer;