aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/libraries/elementary/src/examples/efl_thread_5.c
diff options
context:
space:
mode:
Diffstat (limited to 'libraries/elementary/src/examples/efl_thread_5.c')
-rw-r--r--libraries/elementary/src/examples/efl_thread_5.c104
1 files changed, 104 insertions, 0 deletions
diff --git a/libraries/elementary/src/examples/efl_thread_5.c b/libraries/elementary/src/examples/efl_thread_5.c
new file mode 100644
index 0000000..4e53dd0
--- /dev/null
+++ b/libraries/elementary/src/examples/efl_thread_5.c
@@ -0,0 +1,104 @@
1//Compile with:
2//gcc -o efl_thread_5 efl_thread_5.c -g `pkg-config --cflags --libs elementary`
3#include <Elementary.h>
4
5static Ecore_Thread *thr = NULL;
6
7static Evas_Object *win = NULL;
8static Evas_Object *rect = NULL;
9
10struct info
11{
12 double x, y;
13};
14
15// BEGIN - code running in my custom thread instance
16//
17static void
18th_do(void *data, Ecore_Thread *th)
19{
20 double t = 0.0;
21
22 // inside our "do" function for the ecore thread, lets do the real work
23 for (;;)
24 {
25 struct info *inf = malloc(sizeof(struct info));
26
27 if (inf)
28 {
29 inf->x = 200 + (200 * sin(t));
30 inf->y = 200 + (200 * cos(t));
31 // now we have recorded the timepoint we pass it as feedback
32 // back to the mainloop. it will free it when done
33 ecore_thread_feedback(th, inf);
34 }
35 // and sleep and loop
36 usleep(1000);
37 t += 0.02;
38 // in case someone has asked us to cancel - then cancel this loop
39 // co-operatively (cancelling is co-operative)
40 if (ecore_thread_check(th)) break;
41 }
42}
43//
44// END - code running in my custom thread instance
45
46static void // when mainloop gets feedback from worker
47th_feedback(void *data, Ecore_Thread *th, void *msg)
48{
49 struct info *inf = msg;
50 evas_object_move(rect, inf->x - 50, inf->y - 50);
51 free(inf);
52}
53
54// BONUS (optional): called after th_do returns and has NOT been cancelled
55static void th_end(void *data, Ecore_Thread *th) { printf("thread ended\n"); }
56// BONUS (optional): called in mainloop AFTER thread has finished cancelling
57static void th_cancel(void *data, Ecore_Thread *th) { printf("thread cancelled\n"); }
58
59// just test cancelling the thread worker
60static void
61down(void *data, Evas *e, Evas_Object *obj, void *event_info)
62{
63 ecore_thread_cancel(thr);
64}
65
66EAPI_MAIN int
67elm_main(int argc, char **argv)
68{
69 Evas_Object *o, *bg;
70
71 win = elm_win_add(NULL, "efl-thread-5", ELM_WIN_BASIC);
72 elm_win_title_set(win, "EFL Thread 5");
73 elm_win_autodel_set(win, EINA_TRUE);
74 elm_policy_set(ELM_POLICY_QUIT, ELM_POLICY_QUIT_LAST_WINDOW_CLOSED);
75 evas_object_resize(win, 400, 400);
76 evas_object_show(win);
77
78 bg = elm_bg_add(win);
79 evas_object_size_hint_weight_set(bg, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
80 elm_win_resize_object_add(win, bg);
81 evas_object_show(bg);
82
83 o = evas_object_rectangle_add(evas_object_evas_get(win));
84 evas_object_color_set(o, 50, 80, 180, 255);
85 evas_object_resize(o, 100, 100);
86 evas_object_show(o);
87 evas_object_event_callback_add(o, EVAS_CALLBACK_MOUSE_DOWN, down, NULL);
88 rect = o;
89
90 // explicitly create ecore thread to do some "work on the side" and pass
91 // in NULL as data ptr to callbacks and true at the end means to actually
92 // make a new thread and not use the thread pool (there is a thread pool
93 // with as many thread workers as there are cpu's so this means you do not
94 // overload the cpu's with more work than you actually have processing
95 // units *IF* your threads do actually spend their time doing actual
96 // heavy computation)
97 thr = ecore_thread_feedback_run(th_do, th_feedback, th_end, th_cancel,
98 NULL, EINA_TRUE);
99 elm_run();
100 elm_shutdown();
101
102 return 0;
103}
104ELM_MAIN()