2010-04-06 07:01:04 -07:00
|
|
|
#include <assert.h>
|
|
|
|
#include "private.h"
|
|
|
|
|
|
|
|
typedef struct _Elm_Params_Genlist
|
|
|
|
{
|
2010-10-21 15:03:43 -07:00
|
|
|
Elm_Params base;
|
2011-08-04 18:21:56 -07:00
|
|
|
const char *horizontal;
|
2010-04-06 07:01:04 -07:00
|
|
|
Eina_Bool multi:1;
|
|
|
|
Eina_Bool multi_exists:1;
|
|
|
|
Eina_Bool always_select:1;
|
|
|
|
Eina_Bool always_select_exists:1;
|
|
|
|
Eina_Bool no_select:1;
|
|
|
|
Eina_Bool no_select_exists:1;
|
|
|
|
Eina_Bool compress_exists:1;
|
|
|
|
Eina_Bool homogeneous:1;
|
|
|
|
Eina_Bool homogeneous_exists:1;
|
|
|
|
Eina_Bool h_bounce:1;
|
|
|
|
Eina_Bool h_bounce_exists:1;
|
|
|
|
Eina_Bool v_bounce:1;
|
|
|
|
Eina_Bool v_bounce_exists:1;
|
|
|
|
} Elm_Params_Genlist;
|
|
|
|
|
2014-01-23 03:08:10 -08:00
|
|
|
static const char* list_horizontal_choices[] =
|
|
|
|
{
|
|
|
|
"compress", "scroll", "limit", "expand",
|
|
|
|
NULL
|
|
|
|
};
|
2010-04-06 07:01:04 -07:00
|
|
|
|
|
|
|
static Elm_List_Mode
|
2011-08-04 18:21:56 -07:00
|
|
|
_list_horizontal_setting_get(const char *horizontal_str)
|
2010-04-06 07:01:04 -07:00
|
|
|
{
|
|
|
|
unsigned int i;
|
|
|
|
|
2014-01-23 03:08:10 -08:00
|
|
|
assert(sizeof(list_horizontal_choices) / sizeof(list_horizontal_choices[0])
|
|
|
|
== ELM_LIST_LAST + 1);
|
2010-04-06 07:01:04 -07:00
|
|
|
|
elementary - fixed some logic errors patched by rajeev.r@samsung.com
Hi all,
I found few memory related issues in elementary package when performed static analysis on it.
These issues include:
Array indices getting out of bounds, freed memory address being passed to a function as parameter, memory not getting cleaned up because of earlier return statement.
Issues details:
1. In elm_widget.c inside function elm_widget_signal_callback_del(), it is possible that freed memory address esd is passed to the sd->callback_del_func(). I think it should be data, not esd.
Moreover what if the callback frees memory for data, then the other problem is that the return value is data from the function elm_widget_signal_callback_del() which in my opinion can be a problem.
2. Inside directory src/edje_externals for files elm_genlist.c, elm_notify.c, elm_list.c, elm_thumb.c and elm_map.c, array indices can go beyound bounary.
sizeof() operator for an array of character pointers will return [number of elements in the array * size of (char*)], basically 4 times the number of elements which has been taken care in assertion inside src/edje_extenarnals
while performing assertion but has been missed in the next statement in the loop condition.
3. In file src/lib/elm_config.c inside function _elm_config_profiles_list, freeing of file iterator has been missed out.
Please review the attached patch and let me know your opinion.
Thanks.
Regards,
Rajeev
SVN revision: 63550
2011-09-22 17:02:13 -07:00
|
|
|
for (i = 0; i < ELM_LIST_LAST; i++)
|
2010-04-06 07:01:04 -07:00
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (!strcmp(horizontal_str, list_horizontal_choices[i]))
|
|
|
|
return i;
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
return ELM_LIST_LAST;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2014-01-23 03:08:10 -08:00
|
|
|
external_genlist_state_set(void *data EINA_UNUSED, Evas_Object *obj,
|
|
|
|
const void *from_params, const void *to_params,
|
|
|
|
float pos EINA_UNUSED)
|
2010-04-06 07:01:04 -07:00
|
|
|
{
|
|
|
|
const Elm_Params_Genlist *p;
|
|
|
|
|
|
|
|
if (to_params) p = to_params;
|
|
|
|
else if (from_params) p = from_params;
|
|
|
|
else return;
|
|
|
|
|
2011-08-04 18:21:56 -07:00
|
|
|
if (p->horizontal)
|
2010-04-06 07:01:04 -07:00
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
Elm_List_Mode set = _list_horizontal_setting_get(p->horizontal);
|
2010-04-06 07:01:04 -07:00
|
|
|
|
2014-01-23 03:08:10 -08:00
|
|
|
if (set != ELM_LIST_LAST)
|
|
|
|
elm_genlist_mode_set(obj, set);
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
if (p->multi_exists)
|
|
|
|
elm_genlist_multi_select_set(obj, p->multi);
|
|
|
|
if (p->no_select_exists)
|
2012-03-07 07:22:12 -08:00
|
|
|
{
|
|
|
|
if (p->no_select)
|
2012-03-07 08:18:38 -08:00
|
|
|
elm_genlist_select_mode_set (obj, ELM_OBJECT_SELECT_MODE_NONE);
|
2012-03-07 07:22:12 -08:00
|
|
|
else
|
2012-03-07 08:18:38 -08:00
|
|
|
elm_genlist_select_mode_set (obj, ELM_OBJECT_SELECT_MODE_DEFAULT);
|
2012-03-07 07:22:12 -08:00
|
|
|
}
|
|
|
|
if (p->always_select_exists)
|
|
|
|
{
|
|
|
|
if (p->always_select)
|
2012-03-07 08:18:38 -08:00
|
|
|
elm_genlist_select_mode_set (obj, ELM_OBJECT_SELECT_MODE_ALWAYS);
|
2012-03-07 07:22:12 -08:00
|
|
|
else
|
2012-03-07 08:18:38 -08:00
|
|
|
elm_genlist_select_mode_set (obj, ELM_OBJECT_SELECT_MODE_DEFAULT);
|
2012-03-07 07:22:12 -08:00
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
if (p->homogeneous_exists)
|
|
|
|
elm_genlist_homogeneous_set(obj, p->homogeneous);
|
|
|
|
if ((p->h_bounce_exists) && (p->v_bounce_exists))
|
2012-07-16 14:56:30 -07:00
|
|
|
elm_scroller_bounce_set(obj, p->h_bounce, p->v_bounce);
|
2010-04-06 07:01:04 -07:00
|
|
|
else if ((p->h_bounce_exists) || (p->v_bounce_exists))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
Eina_Bool h_bounce, v_bounce;
|
2010-04-06 07:01:04 -07:00
|
|
|
|
2014-01-23 03:08:10 -08:00
|
|
|
elm_scroller_bounce_get(obj, &h_bounce, &v_bounce);
|
|
|
|
if (p->h_bounce_exists)
|
|
|
|
elm_scroller_bounce_set(obj, p->h_bounce, v_bounce);
|
|
|
|
else
|
|
|
|
elm_scroller_bounce_set(obj, h_bounce, p->v_bounce);
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static Eina_Bool
|
2014-01-23 03:08:10 -08:00
|
|
|
external_genlist_param_set(void *data EINA_UNUSED, Evas_Object *obj,
|
|
|
|
const Edje_External_Param *param)
|
2010-04-06 07:01:04 -07:00
|
|
|
{
|
|
|
|
if (!strcmp(param->name, "horizontal mode"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_CHOICE)
|
|
|
|
{
|
|
|
|
Elm_List_Mode set = _list_horizontal_setting_get(param->s);
|
2010-04-06 07:01:04 -07:00
|
|
|
|
2014-01-23 03:08:10 -08:00
|
|
|
if (set == ELM_LIST_LAST) return EINA_FALSE;
|
|
|
|
elm_genlist_mode_set(obj, set);
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "multi select"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
|
|
|
elm_genlist_multi_select_set(obj, param->i);
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "always select"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
2012-03-07 07:22:12 -08:00
|
|
|
if (param->i)
|
2012-03-07 08:18:38 -08:00
|
|
|
elm_genlist_select_mode_set (obj, ELM_OBJECT_SELECT_MODE_ALWAYS);
|
2012-03-07 07:22:12 -08:00
|
|
|
else
|
2012-03-07 08:18:38 -08:00
|
|
|
elm_genlist_select_mode_set (obj, ELM_OBJECT_SELECT_MODE_DEFAULT);
|
2014-01-23 03:08:10 -08:00
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "no select"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
2012-03-07 07:22:12 -08:00
|
|
|
if (param->i)
|
2012-03-07 08:18:38 -08:00
|
|
|
elm_genlist_select_mode_set (obj, ELM_OBJECT_SELECT_MODE_NONE);
|
2012-03-07 07:22:12 -08:00
|
|
|
else
|
2012-03-07 08:18:38 -08:00
|
|
|
elm_genlist_select_mode_set (obj, ELM_OBJECT_SELECT_MODE_DEFAULT);
|
2014-01-23 03:08:10 -08:00
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "homogeneous"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
|
|
|
elm_genlist_homogeneous_set(obj, param->i);
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "height bounce"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
|
|
|
Eina_Bool h_bounce, v_bounce;
|
|
|
|
elm_scroller_bounce_get(obj, &h_bounce, &v_bounce);
|
|
|
|
elm_scroller_bounce_set(obj, param->i, v_bounce);
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "width bounce"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
|
|
|
Eina_Bool h_bounce, v_bounce;
|
|
|
|
elm_scroller_bounce_get(obj, &h_bounce, &v_bounce);
|
|
|
|
elm_scroller_bounce_set(obj, h_bounce, param->i);
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
ERR("unknown parameter '%s' of type '%s'",
|
|
|
|
param->name, edje_external_param_type_str(param->type));
|
|
|
|
|
|
|
|
return EINA_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static Eina_Bool
|
2014-01-23 03:08:10 -08:00
|
|
|
external_genlist_param_get(void *data EINA_UNUSED, const Evas_Object *obj,
|
|
|
|
Edje_External_Param *param)
|
2010-04-06 07:01:04 -07:00
|
|
|
{
|
|
|
|
if (!strcmp(param->name, "horizontal mode"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_CHOICE)
|
|
|
|
{
|
|
|
|
Elm_List_Mode list_horizontal_set = elm_genlist_mode_get(obj);
|
2010-04-06 07:01:04 -07:00
|
|
|
|
2014-01-23 03:08:10 -08:00
|
|
|
if (list_horizontal_set == ELM_LIST_LAST)
|
|
|
|
return EINA_FALSE;
|
2010-04-06 07:01:04 -07:00
|
|
|
|
2014-01-23 03:08:10 -08:00
|
|
|
param->s = list_horizontal_choices[list_horizontal_set];
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "multi select"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
|
|
|
param->i = elm_genlist_multi_select_get(obj);
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "always select"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
2012-03-07 07:22:12 -08:00
|
|
|
if (elm_genlist_select_mode_get (obj) ==
|
2012-03-07 08:18:38 -08:00
|
|
|
ELM_OBJECT_SELECT_MODE_ALWAYS)
|
2012-03-07 07:22:12 -08:00
|
|
|
param->i = EINA_TRUE;
|
|
|
|
else
|
|
|
|
param->i = EINA_FALSE;
|
2014-01-23 03:08:10 -08:00
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "no select"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
2012-03-07 07:22:12 -08:00
|
|
|
if (elm_genlist_select_mode_get (obj) ==
|
2012-03-07 08:18:38 -08:00
|
|
|
ELM_OBJECT_SELECT_MODE_NONE)
|
2012-03-07 07:22:12 -08:00
|
|
|
param->i = EINA_TRUE;
|
|
|
|
else
|
|
|
|
param->i = EINA_FALSE;
|
2014-01-23 03:08:10 -08:00
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "homogeneous"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
|
|
|
param->i = elm_genlist_homogeneous_get(obj);
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "height bounce"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
|
|
|
Eina_Bool h_bounce, v_bounce;
|
|
|
|
elm_scroller_bounce_get(obj, &h_bounce, &v_bounce);
|
|
|
|
param->i = h_bounce;
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "width bounce"))
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (param->type == EDJE_EXTERNAL_PARAM_TYPE_BOOL)
|
|
|
|
{
|
|
|
|
Eina_Bool h_bounce, v_bounce;
|
|
|
|
elm_scroller_bounce_get(obj, &h_bounce, &v_bounce);
|
|
|
|
param->i = v_bounce;
|
|
|
|
return EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
ERR("unknown parameter '%s' of type '%s'",
|
|
|
|
param->name, edje_external_param_type_str(param->type));
|
|
|
|
|
|
|
|
return EINA_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *
|
2014-01-23 03:08:10 -08:00
|
|
|
external_genlist_params_parse(void *data EINA_UNUSED,
|
|
|
|
Evas_Object *obj EINA_UNUSED,
|
|
|
|
const Eina_List *params)
|
2010-04-06 07:01:04 -07:00
|
|
|
{
|
|
|
|
Elm_Params_Genlist *mem;
|
|
|
|
Edje_External_Param *param;
|
|
|
|
const Eina_List *l;
|
|
|
|
|
2010-11-22 04:46:58 -08:00
|
|
|
mem = ELM_NEW(Elm_Params_Genlist);
|
2010-04-06 07:01:04 -07:00
|
|
|
if (!mem)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
EINA_LIST_FOREACH(params, l, param)
|
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
if (!strcmp(param->name, "horizontal mode"))
|
|
|
|
mem->horizontal = eina_stringshare_add(param->s);
|
|
|
|
else if (!strcmp(param->name, "multi select"))
|
|
|
|
{
|
|
|
|
mem->multi = !!param->i;
|
|
|
|
mem->multi_exists = EINA_TRUE;
|
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "always select"))
|
|
|
|
{
|
|
|
|
mem->always_select = !!param->i;
|
|
|
|
mem->always_select_exists = EINA_TRUE;
|
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "no select"))
|
|
|
|
{
|
|
|
|
mem->no_select = !!param->i;
|
|
|
|
mem->no_select_exists = EINA_TRUE;
|
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "homogeneous"))
|
|
|
|
{
|
|
|
|
mem->homogeneous = !!param->i;
|
|
|
|
mem->homogeneous_exists = EINA_TRUE;
|
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "height bounce"))
|
|
|
|
{
|
|
|
|
mem->h_bounce = !!param->i;
|
|
|
|
mem->h_bounce_exists = EINA_TRUE;
|
|
|
|
}
|
|
|
|
else if (!strcmp(param->name, "width bounce"))
|
|
|
|
{
|
|
|
|
mem->v_bounce = !!param->i;
|
|
|
|
mem->v_bounce_exists = EINA_TRUE;
|
|
|
|
}
|
2010-04-06 07:01:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return mem;
|
|
|
|
}
|
|
|
|
|
2014-01-06 06:30:02 -08:00
|
|
|
static Evas_Object *external_genlist_content_get(void *data EINA_UNUSED,
|
2014-01-23 03:08:10 -08:00
|
|
|
const Evas_Object *obj EINA_UNUSED,
|
|
|
|
const char *content EINA_UNUSED)
|
2010-08-01 10:29:20 -07:00
|
|
|
{
|
2014-01-23 03:08:10 -08:00
|
|
|
ERR("No content.");
|
|
|
|
return NULL;
|
2010-08-01 10:29:20 -07:00
|
|
|
}
|
|
|
|
|
2010-04-06 07:01:04 -07:00
|
|
|
static void
|
|
|
|
external_genlist_params_free(void *params)
|
|
|
|
{
|
|
|
|
Elm_Params_Genlist *mem = params;
|
|
|
|
|
2011-08-04 18:21:56 -07:00
|
|
|
if (mem->horizontal)
|
|
|
|
eina_stringshare_del(mem->horizontal);
|
2010-04-06 07:01:04 -07:00
|
|
|
|
|
|
|
free(mem);
|
|
|
|
}
|
|
|
|
|
|
|
|
static Edje_External_Param_Info external_genlist_params[] = {
|
2014-01-23 03:08:10 -08:00
|
|
|
DEFINE_EXTERNAL_COMMON_PARAMS,
|
|
|
|
EDJE_EXTERNAL_PARAM_INFO_CHOICE_FULL("horizontal mode", "scroll",
|
|
|
|
list_horizontal_choices),
|
|
|
|
EDJE_EXTERNAL_PARAM_INFO_BOOL("multi select"),
|
|
|
|
EDJE_EXTERNAL_PARAM_INFO_BOOL("always select"),
|
|
|
|
EDJE_EXTERNAL_PARAM_INFO_BOOL("no select"),
|
|
|
|
EDJE_EXTERNAL_PARAM_INFO_BOOL("homogeneous"),
|
|
|
|
EDJE_EXTERNAL_PARAM_INFO_BOOL("height bounce"),
|
|
|
|
EDJE_EXTERNAL_PARAM_INFO_BOOL("width bounce"),
|
|
|
|
EDJE_EXTERNAL_PARAM_INFO_SENTINEL
|
2010-04-06 07:01:04 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
DEFINE_EXTERNAL_ICON_ADD(genlist, "genlist");
|
|
|
|
DEFINE_EXTERNAL_TYPE_SIMPLE(genlist, "Generic List");
|