summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLarry Jr <larry.olj@gmail.com>2017-06-07 14:23:27 -0300
committerFelipe Magno de Almeida <felipe@expertisesolutions.com.br>2017-06-08 19:12:13 -0300
commit824699036aa54177a88849e2a5b8f5626e443204 (patch)
treea47cdd501e09366ed6e045105d290eeb12d3539e
parent891976ae1c31cd7595becbe86c9047714cf5ce5b (diff)
downloadefl-824699036aa54177a88849e2a5b8f5626e443204.tar.gz
Elementary: fix Elm.Layout Model Connect
Use "elm" has source to model_connect update Disconnect part/property in model_connect
-rw-r--r--src/lib/elementary/elm_layout.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/src/lib/elementary/elm_layout.c b/src/lib/elementary/elm_layout.c
index 79b88ac842..7d5c3fbfd2 100644
--- a/src/lib/elementary/elm_layout.c
+++ b/src/lib/elementary/elm_layout.c
@@ -1931,7 +1931,6 @@ _prop_future_error_cb(void* data, Efl_Event const*event EINA_UNUSED)
static void
_view_update(Elm_Layout_Smart_Data *pd, const char *name, const char *property)
{
- const char *source;
Eina_Strbuf *buf;
if (strncmp(SIGNAL_PREFIX, name, sizeof(SIGNAL_PREFIX) -1) != 0)
@@ -1941,14 +1940,13 @@ _view_update(Elm_Layout_Smart_Data *pd, const char *name, const char *property)
}
ELM_WIDGET_DATA_GET_OR_RETURN(pd->obj, wd);
- source = efl_class_name_get(efl_class_get(pd->model));
buf = eina_strbuf_new();
eina_strbuf_append(buf, name);
eina_strbuf_remove(buf, 0, sizeof(SIGNAL_PREFIX)-1);
eina_strbuf_replace_all(buf, "%v", property);
- edje_object_signal_emit(wd->resize_obj, eina_strbuf_string_get(buf), source);
+ edje_object_signal_emit(wd->resize_obj, eina_strbuf_string_get(buf), "elm");
eina_strbuf_free(buf);
}
@@ -1997,7 +1995,7 @@ _elm_layout_view_model_update(Elm_Layout_Smart_Data *pd)
Eina_Iterator *it_p;
int size;
- if (!pd->prop_connect) return;
+ if (!pd->prop_connect || !pd->model) return;
size = eina_hash_population(pd->prop_connect);
if (size == 0) return;
@@ -2092,6 +2090,8 @@ _elm_layout_efl_ui_view_model_set(Eo *obj EINA_UNUSED, Elm_Layout_Smart_Data *pd
efl_ref(pd->model);
efl_event_callback_add(pd->model, EFL_MODEL_EVENT_PROPERTIES_CHANGED, _efl_model_properties_changed_cb, pd);
}
+ else
+ return;
if (pd->prop_connect)
_elm_layout_view_model_update(pd);
@@ -2137,6 +2137,13 @@ _elm_layout_efl_ui_model_connect_connect(Eo *obj EINA_UNUSED, Elm_Layout_Smart_D
EINA_SAFETY_ON_NULL_RETURN(name);
Eina_Stringshare *ss_name, *ss_prop;
+ if (property == NULL && pd->prop_connect)
+ {
+ ss_name = eina_stringshare_add(name);
+ eina_hash_del(pd->prop_connect, ss_name, NULL);
+ return;
+ }
+
if (!_elm_layout_part_aliasing_eval(obj, pd, &name, EINA_TRUE))
return;