summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFelipe Magno de Almeida <felipe@expertisesolutions.com.br>2016-06-03 16:53:54 -0300
committerFelipe Magno de Almeida <felipe@expertisesolutions.com.br>2016-06-03 17:22:18 -0300
commit865b69f6ff3f095e5d81648c391b2e9fb8519fdf (patch)
tree8255be1d494f5f79f0b4c1086e2c39922ba67d85
parent8fec0d5139a3ff30037ba159bb62ff2f733d96a8 (diff)
downloadefl-865b69f6ff3f095e5d81648c391b2e9fb8519fdf.tar.gz
eina: Fix examples using new Eina_Promise semantics
-rw-r--r--src/examples/eio/eio_job_ls.c8
-rw-r--r--src/examples/eio/eio_job_open.c23
-rw-r--r--src/examples/eio/eio_job_open_multi.c14
-rw-r--r--src/examples/eldbus/dbusmodel.c27
-rw-r--r--src/examples/elementary/filemvc.c2
5 files changed, 35 insertions, 39 deletions
diff --git a/src/examples/eio/eio_job_ls.c b/src/examples/eio/eio_job_ls.c
index 354325e4f8..2e2db1faf6 100644
--- a/src/examples/eio/eio_job_ls.c
+++ b/src/examples/eio/eio_job_ls.c
@@ -18,11 +18,11 @@ void done_cb(void *data, void *value EINA_UNUSED)
eo_unref(job);
}
-void error_cb(void *data, Eina_Error *error)
+void error_cb(void *data, Eina_Error error)
{
Eio_Job *job = data;
EINA_SAFETY_ON_NULL_RETURN(error);
- const char *msg = eina_error_msg_get(*error);
+ const char *msg = eina_error_msg_get(error);
printf("%s error: %s\n", __FUNCTION__, msg);
ecore_main_loop_quit();
@@ -54,9 +54,9 @@ void list_files(void *data)
Eio_Job *job = eo_add(EIO_JOB_CLASS, NULL);
eo_event_callback_add(job, EIO_JOB_EVENT_FILTER_NAME, (Eo_Event_Cb)&filter_cb, NULL);
- eio_job_file_ls(job, path, &promise);
+ promise = eio_job_file_ls(job, path);
eina_promise_progress_cb_add(promise, (Eina_Promise_Progress_Cb)&progress_cb, NULL, NULL);
- eina_promise_then(promise, (Eina_Promise_Cb)&done_cb, (Eina_Promise_Error_Cb)&error_cb, job);
+ eina_promise_then(promise, &done_cb, &error_cb, job);
}
int main(int argc, char const *argv[])
diff --git a/src/examples/eio/eio_job_open.c b/src/examples/eio/eio_job_open.c
index fb235c2e06..7662bfb8e7 100644
--- a/src/examples/eio/eio_job_open.c
+++ b/src/examples/eio/eio_job_open.c
@@ -9,18 +9,17 @@
#include <Eio.h>
#include <Ecore.h>
-void error_cb(void *data, Eina_Error *error)
+void error_cb(void *data, Eina_Error error, Eina_Promise* promise EINA_UNUSED)
{
- EINA_SAFETY_ON_NULL_RETURN(error);
EINA_SAFETY_ON_NULL_RETURN(data);
- const char *msg = eina_error_msg_get(*error);
+ const char *msg = eina_error_msg_get(error);
EINA_LOG_ERR("error: %s", msg);
ecore_main_loop_quit();
}
-void done_closing_cb(int *result EINA_UNUSED)
+void done_closing_cb(void* data EINA_UNUSED, void *value EINA_UNUSED, Eina_Promise* promise EINA_UNUSED)
{
printf("%s closed file.\n", __FUNCTION__);
@@ -32,21 +31,22 @@ void closing_job(Eio_Job *job, Eina_File *file)
Eina_Promise *promise = NULL;
printf("%s Will close the file...\n", __FUNCTION__);
eio_job_file_close(job, file, &promise);
- eina_promise_then(promise, (Eina_Promise_Cb)&done_closing_cb, (Eina_Promise_Error_Cb)&error_cb, job);
+ eina_promise_then(promise, &done_closing_cb, &error_cb, job);
}
-void done_open_cb(void *data, Eina_File **file)
+void done_open_cb(void *data, void* value, Eina_Promise* promise)
{
EINA_SAFETY_ON_NULL_RETURN(data);
- EINA_SAFETY_ON_NULL_RETURN(file);
- EINA_SAFETY_ON_NULL_RETURN(*file);
+ EINA_SAFETY_ON_NULL_RETURN(value);
+
+ Eina_File *file = eina_file_dup(value);
Eio_Job *job = data;
- const char *name = eina_file_filename_get(*file);
+ const char *name = eina_file_filename_get(file);
printf("%s opened file %s\n", __FUNCTION__, name);
- closing_job(job, *file);
+ closing_job(job, file);
}
void open_file(const char *path)
@@ -54,8 +54,7 @@ void open_file(const char *path)
Eina_Promise *promise;
Eio_Job *job = eo_add(EIO_JOB_CLASS, NULL);
- eio_job_file_open(job, path, EINA_FALSE, &promise);
- eina_promise_then(promise, (Eina_Promise_Cb)&done_open_cb, (Eina_Promise_Error_Cb)&error_cb, job);
+ eina_promise_then(eio_job_file_open(job, path, EINA_FALSE), &done_open_cb, &error_cb, job);
eo_unref(job);
}
diff --git a/src/examples/eio/eio_job_open_multi.c b/src/examples/eio/eio_job_open_multi.c
index 8082d4bfac..d1f8fa97bd 100644
--- a/src/examples/eio/eio_job_open_multi.c
+++ b/src/examples/eio/eio_job_open_multi.c
@@ -9,12 +9,12 @@
#include <Eio.h>
#include <Ecore.h>
-void error_cb(void *data, Eina_Error *error)
+void error_cb(void *data, Eina_Error error)
{
EINA_SAFETY_ON_NULL_RETURN(error);
EINA_SAFETY_ON_NULL_RETURN(data);
- const char *msg = eina_error_msg_get(*error);
+ const char *msg = eina_error_msg_get(error);
EINA_LOG_ERR("error: %s", msg);
Eio_Job *job = data;
@@ -23,10 +23,12 @@ void error_cb(void *data, Eina_Error *error)
ecore_main_loop_quit();
}
-void done_closing_cb(void *data, Eina_Iterator **result EINA_UNUSED)
+void done_closing_cb(void *data, void* value EINA_UNUSED)
{
EINA_SAFETY_ON_NULL_RETURN(data);
+ Eina_Iterator* result = value;
+
printf("%s closed file.\n", __FUNCTION__);
Eio_Job *job = data;
@@ -44,7 +46,7 @@ void closing_job(Eio_Job *job, Eina_File *file1, Eina_File *file2)
eio_job_file_close(job, file1, &tasks[0]);
eio_job_file_close(job, file2, &tasks[1]);
promise = eina_promise_all(eina_carray_iterator_new((void**)&tasks[0]));
- eina_promise_then(promise, (Eina_Promise_Cb)&done_closing_cb, (Eina_Promise_Error_Cb)&error_cb, job);
+ eina_promise_then(promise, &done_closing_cb, &error_cb, job);
}
void done_open_cb(void *data, Eina_Iterator **iterator)
@@ -74,8 +76,8 @@ void open_file(const char *path, const char *path2)
Eina_Promise *tasks[3] = {NULL, NULL, NULL};
Eio_Job *job = eo_add(EIO_JOB_CLASS, NULL);
- eio_job_file_open(job, path, EINA_FALSE, &tasks[0]);
- eio_job_file_open(job, path2, EINA_FALSE, &tasks[1]);
+ tasks[0] = eio_job_file_open(job, path, EINA_FALSE);
+ tasks[1] = eio_job_file_open(job, path2, EINA_FALSE);
promise = eina_promise_all(eina_carray_iterator_new((void**)&tasks[0]));
eina_promise_then(promise, (Eina_Promise_Cb)&done_open_cb, (Eina_Promise_Error_Cb)&error_cb, job);
}
diff --git a/src/examples/eldbus/dbusmodel.c b/src/examples/eldbus/dbusmodel.c
index a7c8ee7dac..4cc7178176 100644
--- a/src/examples/eldbus/dbusmodel.c
+++ b/src/examples/eldbus/dbusmodel.c
@@ -15,21 +15,15 @@
static int prop_count = 0;
-struct eina_iterator
-{
- Eina_Iterator* success_iterator;
- Eina_Iterator* failure_iterator;
-};
-
static void
-promise_then_prop_c(Eo* obj, struct eina_iterator* it_struct)
+promise_then_prop_c(Eo* obj, void* data)
{
Eina_Value * property_value;
const Eina_Array *properties_list;
Eina_Array_Iterator a_it;
char *property, *prop_str;
const char *name;
- Eina_Iterator* it = it_struct->success_iterator;
+ Eina_Iterator* it = data;
name = eldbus_model_proxy_name_get(obj);
properties_list = efl_model_properties_get(obj);
@@ -59,7 +53,7 @@ error_cb(void* data EINA_UNUSED, const Eina_Error *error EINA_UNUSED)
}
static void
-promise_then_a(Eo* obj EINA_UNUSED, Eina_Accessor **accessor)
+promise_then_a(Eo* obj EINA_UNUSED, void* data)
{
const Eina_Array *properties_list;
Eina_Array_Iterator a_it;
@@ -68,8 +62,9 @@ promise_then_a(Eo* obj EINA_UNUSED, Eina_Accessor **accessor)
char *property;
Eo* child;
int i = 0;
+ Eina_Accessor* accessor = data;
- EINA_ACCESSOR_FOREACH(*accessor, i, child)
+ EINA_ACCESSOR_FOREACH(accessor, i, child)
{
properties_list = efl_model_properties_get(child);
name = eldbus_model_proxy_name_get(child);
@@ -87,7 +82,7 @@ promise_then_a(Eo* obj EINA_UNUSED, Eina_Accessor **accessor)
efl_model_property_get(child, property, &promises[j]);
}
eina_promise_then(eina_promise_all(eina_carray_iterator_new((void **)promises)),
- (Eina_Promise_Cb)&promise_then_prop_c, &error_cb, child);
+ &promise_then_prop_c, &error_cb, child);
prop_count++;
}
else
@@ -100,14 +95,14 @@ promise_then_a(Eo* obj EINA_UNUSED, Eina_Accessor **accessor)
ecore_main_loop_quit();
}
static void
-promise_then(Eo* obj EINA_UNUSED, struct eina_iterator* it_struct)
+promise_then(Eo* obj EINA_UNUSED, void* data)
{
- Eina_Accessor **accessor;
+ Eina_Accessor *accessor;
unsigned int* count;
- Eina_Iterator* iterator = it_struct->success_iterator;
+ Eina_Iterator* iterator = data;
- if (!eina_iterator_next(iterator, (void **)&accessor))
+ if (!eina_iterator_next(iterator, (void**)&accessor))
{
printf("bye\n");
ecore_main_loop_quit();
@@ -144,7 +139,7 @@ main(int argc, char **argv EINA_UNUSED)
efl_model_children_count_get(root, &promises[1]);
eina_promise_then(eina_promise_all(eina_carray_iterator_new((void **)promises)),
- (Eina_Promise_Cb)&promise_then, &error_cb, root);
+ &promise_then, &error_cb, root);
ecore_main_loop_begin();
diff --git a/src/examples/elementary/filemvc.c b/src/examples/elementary/filemvc.c
index f33b2002eb..1f05feb238 100644
--- a/src/examples/elementary/filemvc.c
+++ b/src/examples/elementary/filemvc.c
@@ -65,7 +65,7 @@ _promise_then(void *data, void *value)
char *path;
Eo *model;
- eina_value_get((Eina_Value *)value, &path);
+ eina_value_get(value, &path);
model = eo_add(EIO_MODEL_CLASS, NULL, eio_model_path_set(eo_self, path));
elm_view_list_model_set(priv->fileview, model);
}