forked from enlightenment/enlightenment
e17: e_widget_ilist: avoid too much idling
SVN revision: 57791
This commit is contained in:
parent
c83350c141
commit
acfadd535b
|
@ -71,13 +71,15 @@ static enum _Queue_Command
|
||||||
CMD_SHOW
|
CMD_SHOW
|
||||||
} Queue_Command;
|
} Queue_Command;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static Eina_Bool
|
static Eina_Bool
|
||||||
_queue_idler(void *data)
|
_queue_idler(void *data)
|
||||||
{
|
{
|
||||||
Evas_Object *obj;
|
Evas_Object *obj;
|
||||||
E_Widget_Data *wd;
|
E_Widget_Data *wd;
|
||||||
int num;
|
int num;
|
||||||
|
double start = ecore_time_get();
|
||||||
|
|
||||||
obj = data;
|
obj = data;
|
||||||
wd = e_widget_data_get(obj);
|
wd = e_widget_data_get(obj);
|
||||||
|
@ -194,8 +196,9 @@ _queue_idler(void *data)
|
||||||
else if (qi->command == CMD_END_SET)
|
else if (qi->command == CMD_END_SET)
|
||||||
e_ilist_nth_end_set(wd->o_ilist, qi->item, qi->end);
|
e_ilist_nth_end_set(wd->o_ilist, qi->item, qi->end);
|
||||||
_queue_remove(obj, qi, 0);
|
_queue_remove(obj, qi, 0);
|
||||||
num++;
|
|
||||||
if (num >= 10) break;
|
if ((num++ >= 10) && (ecore_time_get() - start > 0.01))
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
e_widget_ilist_thaw(obj);
|
e_widget_ilist_thaw(obj);
|
||||||
e_widget_ilist_go(obj);
|
e_widget_ilist_go(obj);
|
||||||
|
|
Loading…
Reference in New Issue