2 * Copyright (c) 2011-2017 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the License);
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an AS IS BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
19 #define LOG_TAG "TIZEN_N_EFL_UTIL"
26 #include <sys/types.h>
30 #include <tbm_bufmgr.h>
31 #include <tbm_surface.h>
32 #include <tbm_surface_internal.h>
33 #include <Elementary.h>
34 #include <Ecore_Evas.h>
37 #include <Ecore_Wl2.h>
38 #include <wayland-client.h>
39 #include <wayland-tbm-client.h>
40 #include <tizen-extension-client-protocol.h>
42 #include <efl_util_screenshot_extension.h>
49 #define LOG_TAG "TIZEN_N_EFL_UTIL"
50 #define EFL_UTIL_INPUT_GENERATOR_TOUCH_MAX_FINGER 10
52 #define NUM_EVENT_WAIT_DONE_COUNT 10
54 typedef struct _Efl_Util_Wl_Surface_Lv_Info
56 void *surface; /* wl_surface */
58 Eina_Bool wait_for_done;
60 } Efl_Util_Wl_Surface_Lv_Info;
62 typedef struct _Efl_Util_Wl_Surface_Scr_Mode_Info
64 void *surface; /* wl_surface */
66 Eina_Bool wait_for_done;
68 } Efl_Util_Wl_Surface_Scr_Mode_Info;
70 typedef struct _Efl_Util_Wl_Surface_Brightness_Info
72 void *surface; /* wl_surface */
74 Eina_Bool wait_for_done;
76 } Efl_Util_Wl_Surface_Brightness_Info;
78 typedef struct _Efl_Util_Wl_Output_Info
80 struct wl_output *output;
81 int offset_x, offset_y, width, height;
82 } Efl_Util_Wl_Output_Info;
84 typedef struct _Efl_Util_Gesture_Common_Grab_Data
87 } Efl_Util_Gesture_Common_Grab_Data;
89 typedef struct _Efl_Util_Gesture_Edge_Swipe_Grab_Data
91 Efl_Util_Gesture_Common_Grab_Data base;
94 efl_util_gesture_edge_e edge;
95 efl_util_gesture_edge_size_e edge_size;
96 unsigned int start_point;
97 unsigned int end_point;
98 } Efl_Util_Gesture_Edge_Swipe_Grab_Data;
100 typedef struct _Efl_Util_Gesture_Edge_Drag_Grab_Data
102 Efl_Util_Gesture_Common_Grab_Data base;
104 unsigned int fingers;
105 efl_util_gesture_edge_e edge;
106 efl_util_gesture_edge_size_e edge_size;
107 unsigned int start_point;
108 unsigned int end_point;
109 } Efl_Util_Gesture_Edge_Drag_Grab_Data;
111 typedef struct _Efl_Util_Gesture_Tap_Grab_Data
113 Efl_Util_Gesture_Common_Grab_Data base;
115 unsigned int fingers;
116 unsigned int repeats;
117 } Efl_Util_Gesture_Tap_Grab_Data;
119 typedef struct _Efl_Util_Gesture_Palm_Cover_Grab_Data
121 Efl_Util_Gesture_Common_Grab_Data base;
122 } Efl_Util_Gesture_Palm_Cover_Grab_Data;
124 typedef struct _E_Devicemgr_Inputgen_Touch_Axis
131 } E_Devicemgr_Inputgen_Touch_Axis;
133 typedef struct _Efl_Util_Data
135 /* wayland related stuffs */
139 Ecore_Wl2_Display *wl2_display;
140 struct wl_display *dpy;
141 struct wl_event_queue *queue;
146 struct tizen_policy *proto;
147 Eina_Hash *hash_noti_lv;
148 Eina_Hash *hash_scr_mode;
152 struct wl_event_queue *queue;
153 struct tizen_screenshooter *tz_screenshooter;
154 struct wayland_tbm_client *tbm_client;
155 Eina_List *output_list;
160 struct tizen_input_device_manager *devicemgr;
161 int request_notified;
163 Eina_List *wait_devices;
164 struct wl_event_source *wait_timer;
166 int request_touch_count;
171 struct tizen_display_policy *proto;
172 Eina_Hash *hash_brightness;
177 typedef struct _Efl_Util_Data_Default_Queue
179 /* wayland related stuffs */
183 Ecore_Wl2_Display *wl2_display;
184 struct wl_display *dpy;
189 struct tizen_gesture *proto;
190 int request_notified;
194 } Efl_Util_Data_Default_Queue;
197 static Efl_Util_Data _eflutil =
202 { 0, NULL, NULL, NULL }, /* tizen_policy protocol */
203 { NULL, NULL, NULL, NULL, 0 }, /* screenshooter protocol */
204 { NULL, -1, NULL, NULL, NULL, 0, 0 }, /* tizen_input_device_manager protocol */
205 { 0, NULL, NULL } /* display_policy protocol */
209 static Efl_Util_Data_Default_Queue _eflutil_defaultqueue =
214 { 0, NULL, -1, 0 } /* gesture protocol */
219 static Eina_Bool _wl_init(void);
220 static Eina_Bool _wl_init_default_queue(void);
221 static void _cb_wl_reg_global(void *data, struct wl_registry *reg, unsigned int name, const char *interface, unsigned int version);
222 static void _cb_wl_reg_global_remove(void *data, struct wl_registry *reg, unsigned int name);
223 static void _cb_wl_default_queue_reg_global(void *data, struct wl_registry *reg, unsigned int name, const char *interface, unsigned int version);
224 static void _cb_wl_default_queue_reg_global_remove(void *data, struct wl_registry *reg, unsigned int name);
225 static void _cb_wl_reg_screenshooter_global(void *data, struct wl_registry *reg, unsigned int name, const char *interface, unsigned int version);
226 static void _cb_wl_reg_screenshooter_global_remove(void *data, struct wl_registry *reg, unsigned int name);
227 static void _cb_wl_tz_policy_conformant(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, uint32_t is_conformant);
228 static void _cb_wl_tz_policy_conformant_area(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, uint32_t conformant_part, uint32_t state, int32_t x, int32_t y, int32_t w, int32_t h);
229 static void _cb_wl_tz_policy_notification_done(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, int32_t level, uint32_t state);
230 static void _cb_wl_tz_policy_transient_for_done(void *data, struct tizen_policy *tizen_policy, uint32_t child_id);
231 static void _cb_wl_tz_policy_scr_mode_done(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, uint32_t mode, uint32_t state);
232 static void _cb_wl_tz_policy_iconify_state_changed(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, uint32_t iconified, uint32_t force);
233 static void _cb_wl_tz_policy_supported_aux_hints(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, struct wl_array *hints, uint32_t num_hints);
234 static void _cb_wl_tz_policy_allowed_aux_hint(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, int id);
235 static void _cb_wl_tz_policy_aux_message(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, const char *key, const char *val, struct wl_array *options);
236 static void _cb_wl_conformant_region(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, uint32_t conformant_part, uint32_t state, int32_t x, int32_t y, int32_t w, int32_t h, uint32_t serial);
238 static void _cb_wl_tz_display_policy_brightness_done(void *data, struct tizen_display_policy *tizen_display_policy, struct wl_surface *surface_resource, int32_t brightness, uint32_t state);
240 static void _cb_device_add(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED, uint32_t serial EINA_UNUSED, const char *identifier EINA_UNUSED, struct tizen_input_device *device EINA_UNUSED, struct wl_seat *seat EINA_UNUSED);
241 static void _cb_device_remove(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED, uint32_t serial EINA_UNUSED, const char *identifier EINA_UNUSED, struct tizen_input_device *device EINA_UNUSED, struct wl_seat *seat EINA_UNUSED);
242 static void _cb_error(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED, uint32_t errorcode);
243 static void _cb_block_expired(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED);
244 static void _cb_max_touch_count(void *data EINA_UNUSED, struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED, uint32_t serial EINA_UNUSED, int32_t max_count EINA_UNUSED, struct wl_seat *seat EINA_UNUSED);
246 static void _cb_gesture_edge_swipe_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t fingers EINA_UNUSED, uint32_t edge EINA_UNUSED, uint32_t edge_size EINA_UNUSED, uint32_t start_point EINA_UNUSED, uint32_t end_point EINA_UNUSED, uint32_t error);
247 static void _cb_gesture_edge_swipe(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t mode, uint32_t fingers, int sx, int sy, uint32_t edge);
248 static void _cb_gesture_edge_drag_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t fingers EINA_UNUSED, uint32_t edge EINA_UNUSED, uint32_t edge_size EINA_UNUSED, uint32_t start_point EINA_UNUSED, uint32_t end_point EINA_UNUSED, uint32_t error);
249 static void _cb_gesture_edge_drag(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t mode, uint32_t fingers, int cx, int cy, uint32_t edge);
250 static void _cb_gesture_tap_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t fingers EINA_UNUSED, uint32_t repeats EINA_UNUSED, uint32_t error);
251 static void _cb_gesture_tap(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t mode, uint32_t fingers, uint32_t repeats);
252 static void _cb_gesture_palm_cover_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, struct wl_surface *surface EINA_UNUSED, uint32_t error);
253 static void _cb_gesture_palm_cover(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, struct wl_surface *surface EINA_UNUSED, uint32_t mode, uint32_t duration, int cx, int cy, uint32_t size, wl_fixed_t pressure);
254 static void _cb_gesture_activate_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, struct wl_surface *surface EINA_UNUSED, uint32_t type EINA_UNUSED, uint32_t active EINA_UNUSED, uint32_t error);
257 static const struct wl_registry_listener _wl_reg_listener =
260 _cb_wl_reg_global_remove
263 static const struct wl_registry_listener _wl_reg_screenshooter_listener =
265 _cb_wl_reg_screenshooter_global,
266 _cb_wl_reg_screenshooter_global_remove
269 struct tizen_policy_listener _wl_tz_policy_listener =
271 _cb_wl_tz_policy_conformant,
272 _cb_wl_tz_policy_conformant_area,
273 _cb_wl_tz_policy_notification_done,
274 _cb_wl_tz_policy_transient_for_done,
275 _cb_wl_tz_policy_scr_mode_done,
276 _cb_wl_tz_policy_iconify_state_changed,
277 _cb_wl_tz_policy_supported_aux_hints,
278 _cb_wl_tz_policy_allowed_aux_hint,
279 _cb_wl_tz_policy_aux_message,
280 _cb_wl_conformant_region,
283 struct tizen_input_device_manager_listener _wl_tz_devmgr_listener =
292 struct tizen_display_policy_listener _wl_tz_display_policy_listener =
294 _cb_wl_tz_display_policy_brightness_done,
297 static const struct wl_registry_listener _wl_default_queue_reg_listener =
299 _cb_wl_default_queue_reg_global,
300 _cb_wl_default_queue_reg_global_remove
303 struct tizen_gesture_listener _wl_tz_gesture_listener =
305 _cb_gesture_edge_swipe_notify,
306 _cb_gesture_edge_swipe,
307 _cb_gesture_edge_drag_notify,
308 _cb_gesture_edge_drag,
309 _cb_gesture_tap_notify,
311 _cb_gesture_palm_cover_notify,
312 _cb_gesture_palm_cover,
313 _cb_gesture_activate_notify
319 struct wl_display *display_wrapper = NULL;
320 struct wl_registry *reg = NULL;
322 if (_eflutil.wl.init) return EINA_TRUE;
326 _eflutil.wl.wl2_display = ecore_wl2_display_connect(NULL);
327 EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.wl2_display, fail);
328 _eflutil.wl.dpy = ecore_wl2_display_get(_eflutil.wl.wl2_display);
329 EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.dpy, fail);
331 display_wrapper = wl_proxy_create_wrapper(_eflutil.wl.dpy);
332 EINA_SAFETY_ON_NULL_GOTO(display_wrapper, fail);
334 _eflutil.wl.queue = wl_display_create_queue(_eflutil.wl.dpy);
335 EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.queue, fail);
337 wl_proxy_set_queue((struct wl_proxy *)display_wrapper, _eflutil.wl.queue);
339 reg = wl_display_get_registry(display_wrapper);
340 wl_proxy_wrapper_destroy(display_wrapper);
341 display_wrapper = NULL;
342 EINA_SAFETY_ON_NULL_GOTO(reg, fail);
344 wl_registry_add_listener(reg, &_wl_reg_listener, NULL);
346 _eflutil.wl.init = EINA_TRUE;
351 wl_proxy_wrapper_destroy(display_wrapper);
353 if (_eflutil.wl.queue)
355 wl_event_queue_destroy(_eflutil.wl.queue);
356 _eflutil.wl.queue = NULL;
359 ecore_wl2_shutdown();
364 _wl_init_default_queue(void)
366 struct wl_display *display_wrapper = NULL;
367 struct wl_registry *reg = NULL;
369 if (_eflutil_defaultqueue.wl.init) return EINA_TRUE;
371 if (ecore_wl2_init() <= 0) return EINA_FALSE;
373 _eflutil_defaultqueue.wl.wl2_display = ecore_wl2_connected_display_get(NULL);
374 EINA_SAFETY_ON_NULL_GOTO(_eflutil_defaultqueue.wl.wl2_display, fail);
375 _eflutil_defaultqueue.wl.dpy = ecore_wl2_display_get(_eflutil_defaultqueue.wl.wl2_display);
376 EINA_SAFETY_ON_NULL_GOTO(_eflutil_defaultqueue.wl.dpy, fail);
378 display_wrapper = wl_proxy_create_wrapper(_eflutil_defaultqueue.wl.dpy);
379 EINA_SAFETY_ON_NULL_GOTO(display_wrapper, fail);
381 reg = wl_display_get_registry(display_wrapper);
382 wl_proxy_wrapper_destroy(display_wrapper);
383 display_wrapper = NULL;
384 EINA_SAFETY_ON_NULL_GOTO(reg, fail);
386 wl_registry_add_listener(reg, &_wl_default_queue_reg_listener, NULL);
388 _eflutil_defaultqueue.wl.init = EINA_TRUE;
393 ecore_wl2_shutdown();
398 _cb_wl_output_geometry(void *data, struct wl_output *wl_output, int x, int y,
399 int physical_width, int physical_height, int subpixel,
400 const char *make, const char *model, int transform)
402 Efl_Util_Wl_Output_Info *output = wl_output_get_user_data(wl_output);
403 if (wl_output == output->output)
405 output->offset_x = x;
406 output->offset_y = y;
411 _cb_wl_output_mode(void *data, struct wl_output *wl_output, uint32_t flags,
412 int width, int height, int refresh)
414 Efl_Util_Wl_Output_Info *output = wl_output_get_user_data(wl_output);
415 if (wl_output == output->output && (flags & WL_OUTPUT_MODE_CURRENT))
417 output->width = width;
418 output->height = height;
423 _cb_wl_output_done(void *data, struct wl_output *wl_output)
428 _cb_wl_output_scale(void *data, struct wl_output *wl_output, int32_t factor)
432 static const struct wl_output_listener output_listener =
434 _cb_wl_output_geometry,
441 _cb_tz_screenshot_format(void *data, struct tizen_screenshooter *tz_screenshooter, uint32_t format)
446 _cb_tz_screenshot_noti(void *data, struct tizen_screenshooter *tz_screenshooter, uint32_t noti)
448 _eflutil.wl.shot.noti = noti;
452 _cb_tz_screenshot_done(void *data, struct tizen_screenshooter *tz_screenshooter)
454 Eina_Bool *shot_done = (Eina_Bool*)data;
456 *shot_done = EINA_TRUE;
459 static const struct tizen_screenshooter_listener tz_screenshooter_listener =
461 _cb_tz_screenshot_format,
462 _cb_tz_screenshot_noti,
463 _cb_tz_screenshot_done,
467 _cb_wl_reg_global(void *data,
468 struct wl_registry *reg,
470 const char *interface,
471 unsigned int version)
473 if (!strcmp(interface, "tizen_policy"))
475 struct tizen_policy *proto;
476 proto = wl_registry_bind(reg,
478 &tizen_policy_interface,
482 tizen_policy_add_listener(proto,
483 &_wl_tz_policy_listener,
486 _eflutil.wl.policy.hash_noti_lv = eina_hash_pointer_new(free);
487 _eflutil.wl.policy.hash_scr_mode = eina_hash_pointer_new(free);
488 _eflutil.wl.policy.proto = proto;
489 _eflutil.wl.policy.id = id;
491 else if (strcmp(interface, "wl_output") == 0)
493 Efl_Util_Wl_Output_Info *output = calloc(1, sizeof(Efl_Util_Wl_Output_Info));
494 EINA_SAFETY_ON_NULL_RETURN(output);
496 _eflutil.wl.shot.output_list = eina_list_append(_eflutil.wl.shot.output_list, output);
498 output->output = wl_registry_bind(reg, id, &wl_output_interface, version);
499 wl_output_add_listener(output->output, &output_listener, output);
501 else if (strcmp(interface, "tizen_input_device_manager") == 0)
503 _eflutil.wl.devmgr.devicemgr = wl_registry_bind(reg, id, &tizen_input_device_manager_interface, version);
504 tizen_input_device_manager_add_listener(_eflutil.wl.devmgr.devicemgr, &_wl_tz_devmgr_listener, NULL);
506 else if (!strcmp(interface, "tizen_display_policy"))
508 _eflutil.wl.display_policy.proto = wl_registry_bind(reg, id, &tizen_display_policy_interface, version);
509 if (!_eflutil.wl.display_policy.proto) return;
511 tizen_display_policy_add_listener(_eflutil.wl.display_policy.proto,
512 &_wl_tz_display_policy_listener,
515 _eflutil.wl.display_policy.hash_brightness = eina_hash_pointer_new(free);
516 _eflutil.wl.display_policy.id = id;
519 /* LCOV_EXCL_START */
521 _cb_wl_reg_global_remove(void *data,
522 struct wl_registry *reg,
525 /* unset each global id number to 0 since global id is started
526 * from number 1 on server side display structure
528 if (id == _eflutil.wl.policy.id)
530 _eflutil.wl.policy.id = 0;
531 _eflutil.wl.policy.proto = NULL;
532 eina_hash_free(_eflutil.wl.policy.hash_noti_lv);
533 eina_hash_free(_eflutil.wl.policy.hash_scr_mode);
535 else if (id == _eflutil.wl.display_policy.id)
537 _eflutil.wl.display_policy.id = 0;
538 _eflutil.wl.display_policy.proto = NULL;
539 eina_hash_free(_eflutil.wl.display_policy.hash_brightness);
545 _cb_wl_default_queue_reg_global(void *data,
546 struct wl_registry *reg,
548 const char *interface,
549 unsigned int version)
551 if (strcmp(interface, "tizen_gesture") == 0)
553 _eflutil_defaultqueue.wl.gesture.id = id;
554 _eflutil_defaultqueue.wl.gesture.proto = wl_registry_bind(reg, id, &tizen_gesture_interface, version);
555 tizen_gesture_add_listener(_eflutil_defaultqueue.wl.gesture.proto, &_wl_tz_gesture_listener, NULL);
558 /* LCOV_EXCL_START */
560 _cb_wl_default_queue_reg_global_remove(void *data,
561 struct wl_registry *reg,
564 if (id == _eflutil_defaultqueue.wl.gesture.id)
566 _eflutil_defaultqueue.wl.gesture.id = 0;
567 _eflutil_defaultqueue.wl.gesture.proto = NULL;
574 _cb_wl_reg_screenshooter_global(void *data,
575 struct wl_registry *reg,
577 const char *interface,
578 unsigned int version)
580 if (strcmp(interface, "tizen_screenshooter") == 0)
582 _eflutil.wl.shot.tz_screenshooter = wl_registry_bind(reg, name, &tizen_screenshooter_interface, version);
583 tizen_screenshooter_add_listener(_eflutil.wl.shot.tz_screenshooter, &tz_screenshooter_listener, NULL);
585 wl_display_roundtrip_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
589 /* LCOV_EXCL_START */
591 _cb_wl_reg_screenshooter_global_remove(void *data,
592 struct wl_registry *reg,
598 _cb_wl_tz_policy_conformant(void *data, struct tizen_policy *tizen_policy,
599 struct wl_surface *surface, uint32_t is_conformant)
604 _cb_wl_tz_policy_conformant_area(void *data, struct tizen_policy *tizen_policy,
605 struct wl_surface *surface, uint32_t conformant_part,
606 uint32_t state, int32_t x, int32_t y, int32_t w, int32_t h)
612 _cb_wl_tz_policy_notification_done(void *data,
613 struct tizen_policy *tizen_policy,
614 struct wl_surface *surface,
618 Efl_Util_Wl_Surface_Lv_Info *lv_info;
620 lv_info = eina_hash_find(_eflutil.wl.policy.hash_noti_lv, &surface);
623 lv_info->level = level;
624 lv_info->wait_for_done = EINA_FALSE;
625 lv_info->state = state;
629 /* LCOV_EXCL_START */
631 _cb_wl_tz_policy_transient_for_done(void *data, struct tizen_policy *tizen_policy, uint32_t child_id)
637 _cb_wl_tz_policy_scr_mode_done(void *data,
638 struct tizen_policy *tizen_policy,
639 struct wl_surface *surface,
643 Efl_Util_Wl_Surface_Scr_Mode_Info *scr_mode_info;
645 scr_mode_info = eina_hash_find(_eflutil.wl.policy.hash_scr_mode, &surface);
648 scr_mode_info->mode = mode;
649 scr_mode_info->wait_for_done = EINA_FALSE;
650 scr_mode_info->state = state;
654 /* LCOV_EXCL_START */
655 static void _cb_wl_tz_policy_iconify_state_changed(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, uint32_t iconified, uint32_t force)
659 static void _cb_wl_tz_policy_supported_aux_hints(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, struct wl_array *hints, uint32_t num_hints)
663 static void _cb_wl_tz_policy_allowed_aux_hint(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, int id)
667 static void _cb_wl_tz_policy_aux_message(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface_resource, const char *key, const char *val, struct wl_array *options)
670 static void _cb_wl_conformant_region(void *data, struct tizen_policy *tizen_policy, struct wl_surface *surface, uint32_t conformant_part, uint32_t state, int32_t x, int32_t y, int32_t w, int32_t h, uint32_t serial)
676 _cb_wl_tz_display_policy_brightness_done(void *data,
677 struct tizen_display_policy *tizen_display_policy,
678 struct wl_surface *surface,
682 Efl_Util_Wl_Surface_Brightness_Info *brightness_info;
684 brightness_info = eina_hash_find(_eflutil.wl.display_policy.hash_brightness, &surface);
687 brightness_info->brightness = brightness;
688 brightness_info->wait_for_done = EINA_FALSE;
689 brightness_info->state = state;
694 _cb_window_del(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
696 Efl_Util_Wl_Surface_Lv_Info *lv_info;
699 if (EINA_UNLIKELY(!lv_info))
702 eina_hash_del(_eflutil.wl.policy.hash_noti_lv, &lv_info->surface, lv_info);
706 efl_util_set_notification_window_level(Evas_Object *window,
707 efl_util_notification_level_e level)
711 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
712 EINA_SAFETY_ON_FALSE_RETURN_VAL((level >= EFL_UTIL_NOTIFICATION_LEVEL_NONE) &&
713 (level <= EFL_UTIL_NOTIFICATION_LEVEL_TOP),
714 EFL_UTIL_ERROR_INVALID_PARAMETER);
717 Ecore_Wl2_Window *wlwin;
718 struct wl_surface *surface;
719 Efl_Util_Wl_Surface_Lv_Info *lv_info;
720 Ecore_Wl2_Window_Type wl_type;
721 int ret_dispatch = 0;
724 EINA_SAFETY_ON_FALSE_RETURN_VAL(res, EFL_UTIL_ERROR_INVALID_PARAMETER);
726 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
727 EINA_SAFETY_ON_NULL_RETURN_VAL(wlwin, EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
729 type = elm_win_type_get(window);
730 if (type != ELM_WIN_NOTIFICATION)
732 wl_type = ecore_wl2_window_type_get(wlwin);
733 EINA_SAFETY_ON_FALSE_RETURN_VAL((wl_type == ECORE_WL2_WINDOW_TYPE_NOTIFICATION),
734 EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
737 while (!_eflutil.wl.policy.proto && (ret_dispatch != -1))
738 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
740 surface = ecore_wl2_window_surface_get(wlwin);
741 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
742 EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
744 lv_info = eina_hash_find(_eflutil.wl.policy.hash_noti_lv, &surface);
747 lv_info = calloc(1, sizeof(Efl_Util_Wl_Surface_Lv_Info));
748 EINA_SAFETY_ON_NULL_RETURN_VAL(lv_info, EFL_UTIL_ERROR_OUT_OF_MEMORY);
750 lv_info->surface = surface;
751 lv_info->level = (int)level;
752 lv_info->wait_for_done = EINA_TRUE;
753 lv_info->state = TIZEN_POLICY_ERROR_STATE_NONE;
754 eina_hash_add(_eflutil.wl.policy.hash_noti_lv,
758 evas_object_event_callback_add(window, EVAS_CALLBACK_DEL,
759 _cb_window_del, lv_info);
763 lv_info->level = (int)level;
764 lv_info->wait_for_done = EINA_TRUE;
765 lv_info->state = TIZEN_POLICY_ERROR_STATE_NONE;
769 tizen_policy_set_notification_level(_eflutil.wl.policy.proto,
770 surface, (int)level);
772 if (lv_info->wait_for_done)
776 while (lv_info->wait_for_done && (count < NUM_EVENT_WAIT_DONE_COUNT) && (ret_dispatch != -1))
778 ecore_wl2_display_flush(_eflutil.wl.wl2_display);
779 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
783 if (lv_info->wait_for_done)
785 return EFL_UTIL_ERROR_INVALID_PARAMETER;
789 if (lv_info->state == TIZEN_POLICY_ERROR_STATE_PERMISSION_DENIED)
791 return EFL_UTIL_ERROR_PERMISSION_DENIED;
796 return EFL_UTIL_ERROR_NONE;
800 efl_util_get_notification_window_level(Evas_Object *window,
801 efl_util_notification_level_e *level)
805 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
806 EINA_SAFETY_ON_NULL_RETURN_VAL(level, EFL_UTIL_ERROR_INVALID_PARAMETER);
809 Ecore_Wl2_Window *wlwin;
810 struct wl_surface *surface;
811 Efl_Util_Wl_Surface_Lv_Info *lv_info;
812 Ecore_Wl2_Window_Type wl_type;
813 int ret_dispatch = 0;
816 EINA_SAFETY_ON_FALSE_RETURN_VAL(res, EFL_UTIL_ERROR_INVALID_PARAMETER);
818 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
819 EINA_SAFETY_ON_NULL_RETURN_VAL(wlwin, EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
821 type = elm_win_type_get(window);
822 if (type != ELM_WIN_NOTIFICATION)
824 wl_type = ecore_wl2_window_type_get(wlwin);
825 EINA_SAFETY_ON_FALSE_RETURN_VAL((wl_type == ECORE_WL2_WINDOW_TYPE_NOTIFICATION),
826 EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
829 while (!_eflutil.wl.policy.proto && (ret_dispatch != -1))
830 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
832 surface = ecore_wl2_window_surface_get(wlwin);
833 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
834 EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE);
836 lv_info = eina_hash_find(_eflutil.wl.policy.hash_noti_lv, &surface);
839 if (lv_info->wait_for_done)
843 while ((lv_info->wait_for_done) && (count < NUM_EVENT_WAIT_DONE_COUNT) && (ret_dispatch != -1))
845 ecore_wl2_display_flush(_eflutil.wl.wl2_display);
846 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
850 if (lv_info->wait_for_done)
852 *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
853 return EFL_UTIL_ERROR_INVALID_PARAMETER;
857 switch (lv_info->level)
859 case TIZEN_POLICY_LEVEL_NONE: *level = EFL_UTIL_NOTIFICATION_LEVEL_NONE; break;
860 case TIZEN_POLICY_LEVEL_DEFAULT: *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT; break;
861 case TIZEN_POLICY_LEVEL_MEDIUM: *level = EFL_UTIL_NOTIFICATION_LEVEL_MEDIUM; break;
862 case TIZEN_POLICY_LEVEL_HIGH: *level = EFL_UTIL_NOTIFICATION_LEVEL_HIGH; break;
863 case TIZEN_POLICY_LEVEL_TOP: *level = EFL_UTIL_NOTIFICATION_LEVEL_TOP; break;
864 default: *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
865 return EFL_UTIL_ERROR_INVALID_PARAMETER;
867 return EFL_UTIL_ERROR_NONE;
870 *level = EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT;
872 return EFL_UTIL_ERROR_NONE;
876 efl_util_set_window_opaque_state(Evas_Object *window,
881 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
882 EINA_SAFETY_ON_FALSE_RETURN_VAL(((opaque >= 0) && (opaque <= 1)),
883 EFL_UTIL_ERROR_INVALID_PARAMETER);
885 Ecore_Wl2_Window *wlwin;
886 struct wl_surface *surface;
888 if (!_eflutil.wl.policy.proto)
893 EINA_SAFETY_ON_FALSE_RETURN_VAL(res, EFL_UTIL_ERROR_INVALID_PARAMETER);
895 while (!_eflutil.wl.policy.proto && ret != -1)
896 ret = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
898 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.policy.proto, EFL_UTIL_ERROR_INVALID_PARAMETER);
901 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
903 return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
905 surface = ecore_wl2_window_surface_get(wlwin);
907 return EFL_UTIL_ERROR_NOT_SUPPORTED_WINDOW_TYPE;
909 tizen_policy_set_opaque_state(_eflutil.wl.policy.proto, surface, opaque);
911 return EFL_UTIL_ERROR_NONE;
915 efl_util_set_window_screen_mode(Evas_Object *window,
916 efl_util_screen_mode_e mode)
918 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
919 EINA_SAFETY_ON_FALSE_RETURN_VAL(((mode >= EFL_UTIL_SCREEN_MODE_DEFAULT) &&
920 (mode <= EFL_UTIL_SCREEN_MODE_ALWAYS_ON)),
921 EFL_UTIL_ERROR_INVALID_PARAMETER);
923 Ecore_Wl2_Window *wlwin;
924 struct wl_surface *surface;
925 Efl_Util_Wl_Surface_Scr_Mode_Info *scr_mode_info;
927 int ret_dispatch = 0;
930 EINA_SAFETY_ON_FALSE_RETURN_VAL(res, EFL_UTIL_ERROR_INVALID_PARAMETER);
932 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
935 while (!_eflutil.wl.policy.proto && (ret_dispatch != -1))
936 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
938 surface = ecore_wl2_window_surface_get(wlwin);
939 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
940 EFL_UTIL_ERROR_INVALID_PARAMETER);
942 scr_mode_info = eina_hash_find(_eflutil.wl.policy.hash_scr_mode, &surface);
945 scr_mode_info = calloc(1, sizeof(Efl_Util_Wl_Surface_Scr_Mode_Info));
946 EINA_SAFETY_ON_NULL_RETURN_VAL(scr_mode_info, EFL_UTIL_ERROR_OUT_OF_MEMORY);
948 scr_mode_info->surface = surface;
949 scr_mode_info->mode = (unsigned int)mode;
950 scr_mode_info->wait_for_done = EINA_TRUE;
951 scr_mode_info->state = TIZEN_POLICY_ERROR_STATE_NONE;
953 eina_hash_add(_eflutil.wl.policy.hash_scr_mode,
959 scr_mode_info->mode = (unsigned int)mode;
960 scr_mode_info->wait_for_done = EINA_TRUE;
961 scr_mode_info->state = TIZEN_POLICY_ERROR_STATE_NONE;
964 tizen_policy_set_window_screen_mode(_eflutil.wl.policy.proto,
965 surface, (unsigned int)mode);
966 if (scr_mode_info->wait_for_done)
970 while (scr_mode_info->wait_for_done && (count < NUM_EVENT_WAIT_DONE_COUNT) && (ret_dispatch != -1))
972 ecore_wl2_display_flush(_eflutil.wl.wl2_display);
973 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
977 if (scr_mode_info->wait_for_done)
979 return EFL_UTIL_ERROR_INVALID_PARAMETER;
983 if (scr_mode_info->state == TIZEN_POLICY_ERROR_STATE_PERMISSION_DENIED)
985 return EFL_UTIL_ERROR_PERMISSION_DENIED;
990 return EFL_UTIL_ERROR_NONE;
993 return EFL_UTIL_ERROR_INVALID_PARAMETER;
997 efl_util_get_window_screen_mode(Evas_Object *window,
998 efl_util_screen_mode_e *mode)
1000 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
1001 EINA_SAFETY_ON_NULL_RETURN_VAL(mode, EFL_UTIL_ERROR_INVALID_PARAMETER);
1003 Ecore_Wl2_Window *wlwin;
1004 struct wl_surface *surface;
1005 Efl_Util_Wl_Surface_Scr_Mode_Info *scr_mode_info;
1007 int ret_dispatch = 0;
1010 EINA_SAFETY_ON_FALSE_RETURN_VAL(res, EFL_UTIL_ERROR_INVALID_PARAMETER);
1012 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
1015 while (!_eflutil.wl.policy.proto && (ret_dispatch != -1))
1016 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1018 surface = ecore_wl2_window_surface_get(wlwin);
1019 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
1020 EFL_UTIL_ERROR_INVALID_PARAMETER);
1022 scr_mode_info = eina_hash_find(_eflutil.wl.policy.hash_scr_mode, &surface);
1025 if (scr_mode_info->wait_for_done)
1028 while (scr_mode_info->wait_for_done && (ret_dispatch != -1))
1030 ecore_wl2_display_flush(_eflutil.wl.wl2_display);
1031 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1035 switch (scr_mode_info->mode)
1037 case TIZEN_POLICY_MODE_DEFAULT: *mode = EFL_UTIL_SCREEN_MODE_DEFAULT; break;
1038 case TIZEN_POLICY_MODE_ALWAYS_ON: *mode = EFL_UTIL_SCREEN_MODE_ALWAYS_ON; break;
1039 default: *mode = EFL_UTIL_SCREEN_MODE_DEFAULT;
1040 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1042 return EFL_UTIL_ERROR_NONE;
1046 *mode = EFL_UTIL_SCREEN_MODE_DEFAULT;
1047 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1051 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1055 efl_util_set_window_brightness(Evas_Object *window, int brightness)
1057 Ecore_Wl2_Window *wlwin;
1058 struct wl_surface *surface;
1059 Efl_Util_Wl_Surface_Brightness_Info *brightness_info;
1061 int ret_dispatch = 0;
1063 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
1064 EINA_SAFETY_ON_FALSE_RETURN_VAL(brightness <= 100, EFL_UTIL_ERROR_INVALID_PARAMETER);
1067 EINA_SAFETY_ON_FALSE_RETURN_VAL(res, EFL_UTIL_ERROR_INVALID_PARAMETER);
1069 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
1072 while (!_eflutil.wl.display_policy.proto && (ret_dispatch != -1))
1073 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1075 surface = ecore_wl2_window_surface_get(wlwin);
1076 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
1077 EFL_UTIL_ERROR_INVALID_PARAMETER);
1079 brightness_info = eina_hash_find(_eflutil.wl.display_policy.hash_brightness, &surface);
1080 if (!brightness_info)
1082 brightness_info = calloc(1, sizeof(Efl_Util_Wl_Surface_Brightness_Info));
1083 EINA_SAFETY_ON_NULL_RETURN_VAL(brightness_info, EFL_UTIL_ERROR_OUT_OF_MEMORY);
1085 brightness_info->surface = surface;
1086 brightness_info->brightness = brightness;
1087 brightness_info->wait_for_done = EINA_TRUE;
1088 brightness_info->state = TIZEN_DISPLAY_POLICY_ERROR_STATE_NONE;
1090 eina_hash_add(_eflutil.wl.display_policy.hash_brightness,
1096 brightness_info->brightness = brightness;
1097 brightness_info->wait_for_done = EINA_TRUE;
1098 brightness_info->state = TIZEN_DISPLAY_POLICY_ERROR_STATE_NONE;
1101 tizen_display_policy_set_window_brightness(_eflutil.wl.display_policy.proto,
1102 surface, brightness);
1103 if (brightness_info->wait_for_done)
1107 while (brightness_info->wait_for_done && (count < NUM_EVENT_WAIT_DONE_COUNT) && (ret_dispatch != -1))
1109 ecore_wl2_display_flush(_eflutil.wl.wl2_display);
1110 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1114 if (brightness_info->wait_for_done)
1116 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1120 if (brightness_info->state == TIZEN_DISPLAY_POLICY_ERROR_STATE_PERMISSION_DENIED)
1122 return EFL_UTIL_ERROR_PERMISSION_DENIED;
1126 return EFL_UTIL_ERROR_NONE;
1129 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1133 efl_util_get_window_brightness(Evas_Object *window, int *brightness)
1135 Ecore_Wl2_Window *wlwin;
1136 struct wl_surface *surface;
1137 Efl_Util_Wl_Surface_Brightness_Info *brightness_info;
1139 int ret_dispatch = 0;
1141 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
1142 EINA_SAFETY_ON_NULL_RETURN_VAL(brightness, EFL_UTIL_ERROR_INVALID_PARAMETER);
1145 EINA_SAFETY_ON_FALSE_RETURN_VAL(res, EFL_UTIL_ERROR_INVALID_PARAMETER);
1147 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
1148 if (!wlwin) return EFL_UTIL_ERROR_INVALID_PARAMETER;
1150 while (!_eflutil.wl.display_policy.proto && (ret_dispatch != -1))
1151 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1153 surface = ecore_wl2_window_surface_get(wlwin);
1154 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
1155 EFL_UTIL_ERROR_INVALID_PARAMETER);
1157 brightness_info = eina_hash_find(_eflutil.wl.display_policy.hash_brightness, &surface);
1158 if (brightness_info)
1160 if (brightness_info->wait_for_done)
1163 while (brightness_info->wait_for_done && (ret_dispatch != -1))
1165 ecore_wl2_display_flush(_eflutil.wl.wl2_display);
1166 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1169 *brightness = brightness_info->brightness;
1174 return EFL_UTIL_ERROR_NONE;
1177 struct _efl_util_inputgen_h
1179 unsigned int init_type;
1181 E_Devicemgr_Inputgen_Touch_Axis *axis_info;
1185 _cb_device_add(void *data EINA_UNUSED,
1186 struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED,
1187 uint32_t serial EINA_UNUSED,
1188 const char *identifier EINA_UNUSED,
1189 struct tizen_input_device *device,
1190 struct wl_seat *seat EINA_UNUSED)
1196 _cb_device_remove(void *data EINA_UNUSED,
1197 struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED,
1198 uint32_t serial EINA_UNUSED,
1199 const char *identifier EINA_UNUSED,
1200 struct tizen_input_device *device,
1201 struct wl_seat *seat EINA_UNUSED)
1207 _cb_error(void *data EINA_UNUSED,
1208 struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED,
1211 _eflutil.wl.devmgr.request_notified = errorcode;
1214 /* LCOV_EXCL_START */
1216 _cb_block_expired(void *data EINA_UNUSED,
1217 struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED)
1221 /* LCOV_EXCL_STOP */
1224 _cb_max_touch_count(void *data EINA_UNUSED,
1225 struct tizen_input_device_manager *tizen_input_device_manager EINA_UNUSED,
1226 uint32_t serial EINA_UNUSED,
1228 struct wl_seat *seat EINA_UNUSED)
1230 _eflutil.wl.devmgr.max_touch_count = max_count;
1233 static efl_util_error_e
1234 _efl_util_input_convert_input_generator_error(int ret)
1238 case TIZEN_INPUT_DEVICE_MANAGER_ERROR_NONE:
1239 return EFL_UTIL_ERROR_NONE;
1240 case TIZEN_INPUT_DEVICE_MANAGER_ERROR_NO_PERMISSION:
1241 return EFL_UTIL_ERROR_PERMISSION_DENIED;
1242 case TIZEN_INPUT_DEVICE_MANAGER_ERROR_NO_SYSTEM_RESOURCES:
1243 return EFL_UTIL_ERROR_OUT_OF_MEMORY;
1244 case TIZEN_INPUT_DEVICE_MANAGER_ERROR_INVALID_PARAMETER:
1245 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1246 case TIZEN_INPUT_DEVICE_MANAGER_ERROR_NOT_ALLOWED:
1247 return EFL_UTIL_ERROR_NO_RESOURCE_AVAILABLE;
1249 return EFL_UTIL_ERROR_NONE;
1253 static efl_util_inputgen_h
1254 _efl_util_input_create_inputgen(unsigned int dev_type, const char *name, int *ret, int with_name)
1256 efl_util_inputgen_h inputgen_h = NULL;
1257 unsigned int clas = 0x0;
1258 int ret_dispatch = 0;
1261 dev_type & ~(EFL_UTIL_INPUT_DEVTYPE_TOUCHSCREEN
1262 | EFL_UTIL_INPUT_DEVTYPE_KEYBOARD
1263 | EFL_UTIL_INPUT_DEVTYPE_POINTER))
1265 set_last_result(EFL_UTIL_ERROR_NO_SUCH_DEVICE);
1269 inputgen_h = (efl_util_inputgen_h)calloc(1, sizeof(struct _efl_util_inputgen_h));
1272 set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY);
1276 inputgen_h->init_type |= dev_type;
1279 if (name) strncpy(inputgen_h->name, name, 31);
1280 else strncpy(inputgen_h->name, "Input Generator", 31);
1284 if (*ret == (int)EINA_FALSE)
1286 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
1290 if (dev_type & EFL_UTIL_INPUT_DEVTYPE_TOUCHSCREEN)
1291 clas |= TIZEN_INPUT_DEVICE_MANAGER_CLAS_TOUCHSCREEN;
1292 if (dev_type & EFL_UTIL_INPUT_DEVTYPE_KEYBOARD)
1293 clas |= TIZEN_INPUT_DEVICE_MANAGER_CLAS_KEYBOARD;
1294 if (dev_type & EFL_UTIL_INPUT_DEVTYPE_POINTER)
1295 clas |= TIZEN_INPUT_DEVICE_MANAGER_CLAS_MOUSE;
1297 while (!_eflutil.wl.devmgr.devicemgr && (ret_dispatch != -1))
1298 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1301 tizen_input_device_manager_init_generator_with_sync(_eflutil.wl.devmgr.devicemgr, clas, inputgen_h->name);
1302 else if (with_name == 1)
1303 tizen_input_device_manager_init_generator_with_name(_eflutil.wl.devmgr.devicemgr, clas, inputgen_h->name);
1305 tizen_input_device_manager_init_generator(_eflutil.wl.devmgr.devicemgr, clas);
1308 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1309 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1311 *ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1312 _eflutil.wl.devmgr.request_notified = -1;
1314 set_last_result(*ret);
1315 if (*ret != TIZEN_INPUT_DEVICE_MANAGER_ERROR_NONE)
1329 API efl_util_inputgen_h
1330 efl_util_input_initialize_generator(unsigned int dev_type)
1332 int ret = EFL_UTIL_ERROR_NONE;
1333 efl_util_inputgen_h inputgen_h = NULL;
1335 inputgen_h = _efl_util_input_create_inputgen(dev_type, NULL, &ret, 0);
1342 API efl_util_inputgen_h
1343 efl_util_input_initialize_generator_with_name(unsigned int dev_type, const char *name)
1345 int ret = EFL_UTIL_ERROR_NONE;
1346 efl_util_inputgen_h inputgen_h = NULL;
1348 inputgen_h = _efl_util_input_create_inputgen(dev_type, name, &ret, 1);
1355 API efl_util_inputgen_h
1356 efl_util_input_initialize_generator_with_sync(unsigned int dev_type, const char *name)
1358 int ret = EFL_UTIL_ERROR_NONE;
1359 efl_util_inputgen_h inputgen_h = NULL;
1361 inputgen_h = _efl_util_input_create_inputgen(dev_type, name, &ret, 2);
1369 efl_util_input_set_touch_count(int max_count)
1371 int ret = EFL_UTIL_ERROR_NONE;
1372 int ret_dispatch = 0;
1375 if (ret == (int)EINA_FALSE)
1377 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1380 while (!_eflutil.wl.devmgr.devicemgr && (ret_dispatch != -1))
1381 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1383 if (_eflutil.wl.devmgr.max_touch_count >= max_count)
1384 return EFL_UTIL_ERROR_NONE;
1386 tizen_input_device_manager_set_touch_count(_eflutil.wl.devmgr.devicemgr, max_count);
1389 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1390 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1392 ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1393 _eflutil.wl.devmgr.request_notified = -1;
1395 if (ret == EFL_UTIL_ERROR_NONE)
1397 _eflutil.wl.devmgr.request_touch_count = max_count;
1404 efl_util_input_deinitialize_generator(efl_util_inputgen_h inputgen_h)
1406 int ret = EFL_UTIL_ERROR_NONE;
1407 unsigned int clas = 0x0;
1408 int ret_dispatch = 0;
1409 EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
1411 if (inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_TOUCHSCREEN)
1412 clas |= TIZEN_INPUT_DEVICE_MANAGER_CLAS_TOUCHSCREEN;
1413 if (inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_KEYBOARD)
1414 clas |= TIZEN_INPUT_DEVICE_MANAGER_CLAS_KEYBOARD;
1415 if (inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_POINTER)
1416 clas |= TIZEN_INPUT_DEVICE_MANAGER_CLAS_MOUSE;
1418 if (inputgen_h->axis_info)
1419 free(inputgen_h->axis_info);
1424 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
1426 tizen_input_device_manager_deinit_generator(_eflutil.wl.devmgr.devicemgr, clas);
1428 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1429 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1431 ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1432 _eflutil.wl.devmgr.request_notified = -1;
1438 efl_util_input_generate_key(efl_util_inputgen_h inputgen_h, const char *key_name, int pressed)
1440 int ret = EFL_UTIL_ERROR_NONE;
1441 int ret_dispatch = 0;
1443 EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
1444 EINA_SAFETY_ON_NULL_RETURN_VAL(key_name, EFL_UTIL_ERROR_INVALID_PARAMETER);
1445 EINA_SAFETY_ON_FALSE_RETURN_VAL(pressed == 0 || pressed == 1, EFL_UTIL_ERROR_INVALID_PARAMETER);
1446 EINA_SAFETY_ON_FALSE_RETURN_VAL(inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_KEYBOARD, EFL_UTIL_ERROR_NO_SUCH_DEVICE);
1448 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
1450 tizen_input_device_manager_generate_key(_eflutil.wl.devmgr.devicemgr, key_name, pressed);
1452 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1453 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1455 ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1456 _eflutil.wl.devmgr.request_notified = -1;
1462 efl_util_input_generate_touch(efl_util_inputgen_h inputgen_h, int idx,
1463 efl_util_input_touch_type_e touch_type, int x, int y)
1466 int ret_dispatch = 0;
1467 enum tizen_input_device_manager_pointer_event_type type;
1469 EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
1470 EINA_SAFETY_ON_FALSE_RETURN_VAL(idx >= 0, EFL_UTIL_ERROR_INVALID_PARAMETER);
1471 EINA_SAFETY_ON_FALSE_RETURN_VAL((x > 0 && y > 0), EFL_UTIL_ERROR_INVALID_PARAMETER);
1472 EINA_SAFETY_ON_FALSE_RETURN_VAL(inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_TOUCHSCREEN, EFL_UTIL_ERROR_NO_SUCH_DEVICE);
1474 if (_eflutil.wl.devmgr.request_touch_count != 0 &&
1475 _eflutil.wl.devmgr.max_touch_count != _eflutil.wl.devmgr.request_touch_count)
1476 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1478 if (idx >= _eflutil.wl.devmgr.max_touch_count)
1479 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1481 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
1485 case EFL_UTIL_INPUT_TOUCH_BEGIN:
1486 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_BEGIN;
1488 case EFL_UTIL_INPUT_TOUCH_UPDATE:
1489 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_UPDATE;
1491 case EFL_UTIL_INPUT_TOUCH_END:
1492 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_END;
1495 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1498 tizen_input_device_manager_generate_touch(_eflutil.wl.devmgr.devicemgr, type, x, y, idx);
1500 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1501 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1503 ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1504 _eflutil.wl.devmgr.request_notified = -1;
1510 _efl_util_input_generate_touch_axis_send(unsigned int type, double value)
1513 int ret_dispatch = 0;
1515 tizen_input_device_manager_generate_axis(_eflutil.wl.devmgr.devicemgr, type, wl_fixed_from_double(value));
1517 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1518 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1520 ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1521 _eflutil.wl.devmgr.request_notified = -1;
1527 _efl_util_input_generate_touch_axis_cleanup(efl_util_inputgen_h inputgen_h, int idx)
1532 inputgen_h->axis_info[idx].radius_x = 1.0;
1533 inputgen_h->axis_info[idx].radius_y = 1.0;
1534 inputgen_h->axis_info[idx].pressure = 1.0;
1535 inputgen_h->axis_info[idx].angle = 0.0;
1536 inputgen_h->axis_info[idx].palm = 0.0;
1540 for (i = 0; i < EFL_UTIL_INPUT_GENERATOR_TOUCH_MAX_FINGER; i++)
1542 inputgen_h->axis_info[i].radius_x = 1.0;
1543 inputgen_h->axis_info[i].radius_y = 1.0;
1544 inputgen_h->axis_info[i].pressure = 1.0;
1545 inputgen_h->axis_info[i].angle = 0.0;
1546 inputgen_h->axis_info[i].palm = 0.0;
1552 _efl_util_input_generate_touch_axis_process(efl_util_inputgen_h inputgen_h, int idx, double radius_x,
1553 double radius_y, double pressure, double angle, double palm)
1555 int ret = EFL_UTIL_ERROR_NONE;
1557 if (!inputgen_h->axis_info)
1559 inputgen_h->axis_info = calloc(EFL_UTIL_INPUT_GENERATOR_TOUCH_MAX_FINGER,
1560 sizeof(E_Devicemgr_Inputgen_Touch_Axis));
1561 _efl_util_input_generate_touch_axis_cleanup(inputgen_h, -1);
1564 if (inputgen_h->axis_info[idx].radius_x != radius_x)
1566 ret = _efl_util_input_generate_touch_axis_send(TIZEN_INPUT_DEVICE_MANAGER_AXIS_TYPE_RADIUS_X, radius_x);
1567 if (ret != EFL_UTIL_ERROR_NONE) return ret;
1568 inputgen_h->axis_info[idx].radius_x = radius_x;
1570 if (inputgen_h->axis_info[idx].radius_y != radius_y)
1572 ret = _efl_util_input_generate_touch_axis_send(TIZEN_INPUT_DEVICE_MANAGER_AXIS_TYPE_RADIUS_Y, radius_y);
1573 if (ret != EFL_UTIL_ERROR_NONE) return ret;
1574 inputgen_h->axis_info[idx].radius_y = radius_y;
1576 if (inputgen_h->axis_info[idx].pressure != pressure)
1578 ret = _efl_util_input_generate_touch_axis_send(TIZEN_INPUT_DEVICE_MANAGER_AXIS_TYPE_PRESSURE, pressure);
1579 if (ret != EFL_UTIL_ERROR_NONE) return ret;
1580 inputgen_h->axis_info[idx].pressure = pressure;
1582 if (inputgen_h->axis_info[idx].angle != angle)
1584 ret = _efl_util_input_generate_touch_axis_send(TIZEN_INPUT_DEVICE_MANAGER_AXIS_TYPE_ANGLE, angle);
1585 if (ret != EFL_UTIL_ERROR_NONE) return ret;
1586 inputgen_h->axis_info[idx].angle = angle;
1588 if (inputgen_h->axis_info[idx].palm != palm)
1590 ret = _efl_util_input_generate_touch_axis_send(TIZEN_INPUT_DEVICE_MANAGER_AXIS_TYPE_PALM, palm);
1591 if (ret != EFL_UTIL_ERROR_NONE) return ret;
1592 inputgen_h->axis_info[idx].palm = palm;
1599 efl_util_input_generate_touch_axis(efl_util_inputgen_h inputgen_h, int idx,
1600 efl_util_input_touch_type_e touch_type, int x, int y,
1601 double radius_x, double radius_y,
1602 double pressure, double angle, double palm)
1605 int ret_dispatch = 0;
1606 enum tizen_input_device_manager_pointer_event_type type;
1608 EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
1609 EINA_SAFETY_ON_FALSE_RETURN_VAL(idx >= 0, EFL_UTIL_ERROR_INVALID_PARAMETER);
1610 EINA_SAFETY_ON_FALSE_RETURN_VAL((x >= 0 && y >= 0), EFL_UTIL_ERROR_INVALID_PARAMETER);
1611 EINA_SAFETY_ON_FALSE_RETURN_VAL(inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_TOUCHSCREEN, EFL_UTIL_ERROR_NO_SUCH_DEVICE);
1612 EINA_SAFETY_ON_FALSE_RETURN_VAL((radius_x >= 0.0 && radius_y >= 0.0), EFL_UTIL_ERROR_INVALID_PARAMETER);
1613 EINA_SAFETY_ON_FALSE_RETURN_VAL((pressure >= 0.0 && palm >= 0.0), EFL_UTIL_ERROR_INVALID_PARAMETER);
1615 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
1616 version = tizen_input_device_manager_get_version(_eflutil.wl.devmgr.devicemgr);
1617 EINA_SAFETY_ON_FALSE_RETURN_VAL((version >= 3), EFL_UTIL_ERROR_NOT_SUPPORTED);
1621 case EFL_UTIL_INPUT_TOUCH_BEGIN:
1622 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_BEGIN;
1624 case EFL_UTIL_INPUT_TOUCH_UPDATE:
1625 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_UPDATE;
1627 case EFL_UTIL_INPUT_TOUCH_END:
1628 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_END;
1631 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1634 if (touch_type != EFL_UTIL_INPUT_TOUCH_END)
1635 _efl_util_input_generate_touch_axis_process(inputgen_h, idx, radius_x, radius_y, pressure, angle, palm);
1637 _efl_util_input_generate_touch_axis_cleanup(inputgen_h, idx);
1639 tizen_input_device_manager_generate_touch(_eflutil.wl.devmgr.devicemgr, type, x, y, idx);
1641 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1642 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1644 ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1645 _eflutil.wl.devmgr.request_notified = -1;
1652 efl_util_input_generate_pointer(efl_util_inputgen_h inputgen_h, int buttons, efl_util_input_pointer_type_e pointer_type, int x, int y)
1655 int ret_dispatch = 0;
1656 enum tizen_input_device_manager_pointer_event_type type;
1658 EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
1659 EINA_SAFETY_ON_FALSE_RETURN_VAL(buttons > 0, EFL_UTIL_ERROR_INVALID_PARAMETER);
1660 EINA_SAFETY_ON_FALSE_RETURN_VAL((x >= 0 && y >= 0), EFL_UTIL_ERROR_INVALID_PARAMETER);
1661 EINA_SAFETY_ON_FALSE_RETURN_VAL(inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_POINTER, EFL_UTIL_ERROR_NO_SUCH_DEVICE);
1663 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
1665 switch(pointer_type)
1667 case EFL_UTIL_INPUT_POINTER_BUTTON_DOWN:
1668 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_BEGIN;
1670 case EFL_UTIL_INPUT_POINTER_MOVE:
1671 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_UPDATE;
1673 case EFL_UTIL_INPUT_POINTER_BUTTON_UP:
1674 type = TIZEN_INPUT_DEVICE_MANAGER_POINTER_EVENT_TYPE_END;
1677 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1680 tizen_input_device_manager_generate_pointer(_eflutil.wl.devmgr.devicemgr, type, x, y, buttons);
1682 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1683 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1685 ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1686 _eflutil.wl.devmgr.request_notified = -1;
1692 efl_util_input_generate_wheel(efl_util_inputgen_h inputgen_h, efl_util_input_pointer_wheel_type_e wheel_type, int value)
1695 int ret_dispatch = 0;
1696 enum tizen_input_device_manager_pointer_event_type type;
1698 EINA_SAFETY_ON_NULL_RETURN_VAL(inputgen_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
1699 EINA_SAFETY_ON_FALSE_RETURN_VAL(inputgen_h->init_type & EFL_UTIL_INPUT_DEVTYPE_POINTER, EFL_UTIL_ERROR_NO_SUCH_DEVICE);
1701 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil.wl.devmgr.devicemgr, EFL_UTIL_ERROR_INVALID_PARAMETER);
1702 version = tizen_input_device_manager_get_version(_eflutil.wl.devmgr.devicemgr);
1703 EINA_SAFETY_ON_FALSE_RETURN_VAL((version >= 3), EFL_UTIL_ERROR_NOT_SUPPORTED);
1707 case EFL_UTIL_INPUT_POINTER_WHEEL_VERT:
1708 type = TIZEN_INPUT_DEVICE_MANAGER_AXIS_TYPE_WHEEL;
1710 case EFL_UTIL_INPUT_POINTER_WHEEL_HORZ:
1711 type = TIZEN_INPUT_DEVICE_MANAGER_AXIS_TYPE_HWHEEL;
1714 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1717 tizen_input_device_manager_generate_axis(_eflutil.wl.devmgr.devicemgr, type, wl_fixed_from_int(value));
1719 while ((_eflutil.wl.devmgr.request_notified == -1) && (ret_dispatch != -1))
1720 ret_dispatch = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1722 ret = _efl_util_input_convert_input_generator_error(_eflutil.wl.devmgr.request_notified);
1723 _eflutil.wl.devmgr.request_notified = -1;
1730 struct _efl_util_screenshot_h
1735 Eina_Bool shot_done;
1740 Eina_Bool auto_rotation;
1743 /* scrrenshot handle */
1744 static efl_util_screenshot_h g_screenshot;
1745 static Eina_Bool shot_mutex_init;
1746 static pthread_mutex_t shot_lock;
1749 _screenshot_mutex_init(void)
1751 if (shot_mutex_init)
1754 if (pthread_mutex_init(&shot_lock, NULL))
1756 fprintf(stderr, "[screenshot] fail: mutex init"); /*LCOV_EXCL_LINE*/
1757 return EINA_FALSE; /*LCOV_EXCL_LINE*/
1760 shot_mutex_init = EINA_TRUE;
1766 _screenshot_mutex_destory(void)
1768 if (!shot_mutex_init)
1771 if (pthread_mutex_destroy(&shot_lock))
1773 fprintf(stderr, "[screenshot] fail: mutex destory"); /*LCOV_EXCL_LINE*/
1774 return EINA_FALSE; /*LCOV_EXCL_LINE*/
1777 shot_mutex_init = EINA_FALSE;
1783 _screenshot_mutex_lock(void)
1785 if (!_screenshot_mutex_init())
1788 pthread_mutex_lock(&shot_lock);
1792 _screenshot_mutex_unlock(void)
1794 pthread_mutex_unlock(&shot_lock);
1798 _efl_util_wl_screenshooter_init()
1800 struct wl_display *display_wrapper = NULL;
1801 struct wl_registry *registry = NULL;
1804 if (_wl_init() == EINA_FALSE)
1807 wl_display_roundtrip_queue(_eflutil.wl.dpy, _eflutil.wl.queue);
1809 display_wrapper = wl_proxy_create_wrapper(_eflutil.wl.dpy);
1810 EINA_SAFETY_ON_NULL_RETURN_VAL(display_wrapper, EINA_FALSE);
1812 _eflutil.wl.shot.queue = wl_display_create_queue(_eflutil.wl.dpy);
1813 EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.shot.queue, fail_create_queue);
1815 wl_proxy_set_queue((struct wl_proxy *)display_wrapper, _eflutil.wl.shot.queue);
1817 registry = wl_display_get_registry(display_wrapper);
1818 EINA_SAFETY_ON_NULL_GOTO(registry, fail_get_registry);
1820 wl_registry_add_listener(registry, &_wl_reg_screenshooter_listener, NULL);
1822 ret = wl_display_roundtrip_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
1823 EINA_SAFETY_ON_TRUE_GOTO(ret == -1, fail_roundtrip);
1824 EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.shot.tz_screenshooter, fail_roundtrip);
1826 _eflutil.wl.shot.tbm_client = wayland_tbm_client_init(_eflutil.wl.dpy);
1827 EINA_SAFETY_ON_NULL_GOTO(_eflutil.wl.shot.tbm_client, fail_tbm_client_init);
1829 wl_registry_destroy(registry);
1830 wl_proxy_wrapper_destroy(display_wrapper);
1832 if (_eflutil.wl.shot.noti == 0)
1834 fprintf(stderr, "[screenshot] fail: privilege error\n"); /* LCOV_EXCL_LINE */
1840 fail_tbm_client_init:
1841 tizen_screenshooter_destroy(_eflutil.wl.shot.tz_screenshooter);
1842 _eflutil.wl.shot.tz_screenshooter = NULL;
1844 wl_registry_destroy(registry);
1846 wl_event_queue_destroy(_eflutil.wl.shot.queue);
1847 _eflutil.wl.shot.queue = NULL;
1849 wl_proxy_wrapper_destroy(display_wrapper);
1855 _efl_util_wl_screenshooter_deinit()
1857 if (_eflutil.wl.shot.tbm_client)
1859 wayland_tbm_client_deinit(_eflutil.wl.shot.tbm_client);
1860 _eflutil.wl.shot.tbm_client = NULL;
1863 if (_eflutil.wl.shot.tz_screenshooter)
1865 tizen_screenshooter_destroy(_eflutil.wl.shot.tz_screenshooter);
1866 _eflutil.wl.shot.tz_screenshooter = NULL;
1869 if (_eflutil.wl.shot.queue)
1871 wl_event_queue_destroy(_eflutil.wl.shot.queue);
1872 _eflutil.wl.shot.queue = NULL;
1876 API efl_util_screenshot_h
1877 efl_util_screenshot_initialize(int width, int height)
1879 efl_util_screenshot_h screenshot = NULL;
1881 if (width <= 0 || height <= 0)
1883 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
1887 _screenshot_mutex_lock();
1891 if (g_screenshot->width != width || g_screenshot->height != height)
1893 g_screenshot->width = width;
1894 g_screenshot->height = height;
1896 set_last_result(EFL_UTIL_ERROR_NONE);
1898 _screenshot_mutex_unlock();
1900 return g_screenshot;
1903 screenshot = calloc(1, sizeof(struct _efl_util_screenshot_h));
1904 if (screenshot == NULL)
1906 set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY);
1908 _screenshot_mutex_unlock();
1913 if (!_eflutil.wl.shot.tz_screenshooter)
1915 if (_efl_util_wl_screenshooter_init() == EINA_FALSE)
1917 if (_eflutil.wl.shot.noti == 0)
1918 set_last_result(EFL_UTIL_ERROR_PERMISSION_DENIED);
1920 set_last_result(EFL_UTIL_ERROR_SCREENSHOT_INIT_FAIL);
1924 _screenshot_mutex_unlock();
1930 screenshot->width = width;
1931 screenshot->height = height;
1932 screenshot->auto_rotation = EINA_TRUE;
1934 screenshot->bufmgr = wayland_tbm_client_get_bufmgr(_eflutil.wl.shot.tbm_client);
1935 EINA_SAFETY_ON_NULL_GOTO(screenshot->bufmgr, fail_get_bufmgr);
1937 g_screenshot = screenshot;
1938 set_last_result(EFL_UTIL_ERROR_NONE);
1940 tizen_screenshooter_set_user_data(_eflutil.wl.shot.tz_screenshooter, &screenshot->shot_done);
1942 _screenshot_mutex_unlock();
1944 return g_screenshot;
1946 /* LCOV_EXCL_START */
1948 set_last_result(EFL_UTIL_ERROR_SCREENSHOT_INIT_FAIL);
1949 _screenshot_mutex_unlock();
1950 efl_util_screenshot_deinitialize(screenshot);
1953 /* LCOV_EXCL_STOP */
1957 efl_util_screenshot_deinitialize(efl_util_screenshot_h screenshot)
1959 _screenshot_mutex_lock();
1963 _screenshot_mutex_unlock();
1964 _screenshot_mutex_destory();
1965 return EFL_UTIL_ERROR_INVALID_PARAMETER;
1969 g_screenshot = NULL;
1971 _efl_util_wl_screenshooter_deinit();
1973 _screenshot_mutex_unlock();
1974 _screenshot_mutex_destory();
1976 return EFL_UTIL_ERROR_NONE;
1981 efl_util_screenshot_take_tbm_surface(efl_util_screenshot_h screenshot)
1983 tbm_surface_h t_surface = NULL;
1984 struct wl_buffer *buffer = NULL;
1985 Efl_Util_Wl_Output_Info *output;
1988 _screenshot_mutex_lock();
1990 if (!screenshot || (screenshot != g_screenshot))
1992 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
1993 _screenshot_mutex_unlock();
1997 output = eina_list_nth(_eflutil.wl.shot.output_list, 0);
2000 fprintf(stderr, "[screenshot] fail: no output for screenshot\n"); /* LCOV_EXCL_LINE */
2004 t_surface = tbm_surface_create(screenshot->width, screenshot->height, TBM_FORMAT_XRGB8888);
2007 fprintf(stderr, "[screenshot] fail: tbm_surface_create\n"); /* LCOV_EXCL_LINE */
2011 buffer = wayland_tbm_client_create_buffer(_eflutil.wl.shot.tbm_client, t_surface);
2014 fprintf(stderr, "[screenshot] fail: create wl_buffer for screenshot\n"); /* LCOV_EXCL_LINE */
2018 tizen_screenshooter_shoot(_eflutil.wl.shot.tz_screenshooter, output->output, buffer);
2020 screenshot->shot_done = EINA_FALSE;
2022 while (!screenshot->shot_done && ret != -1)
2023 ret = wl_display_roundtrip_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
2027 fprintf(stderr, "[screenshot] fail: tizen_screenshooter_shoot\n"); /* LCOV_EXCL_LINE */
2031 wayland_tbm_client_destroy_buffer(_eflutil.wl.shot.tbm_client, buffer);
2033 /* reset shot_done for next screenshot */
2034 screenshot->shot_done = EINA_FALSE;
2036 set_last_result(EFL_UTIL_ERROR_NONE);
2038 _screenshot_mutex_unlock();
2044 tbm_surface_destroy(t_surface);
2046 wayland_tbm_client_destroy_buffer(_eflutil.wl.shot.tbm_client, buffer);
2048 set_last_result(EFL_UTIL_ERROR_SCREENSHOT_EXECUTION_FAIL);
2050 _screenshot_mutex_unlock();
2056 efl_util_screenshot_set_auto_rotation(efl_util_screenshot_h screenshot, int set)
2058 if (!screenshot || (screenshot != g_screenshot))
2059 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2061 if (!(set == 0 || set == 1))
2062 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2065 g_screenshot->auto_rotation = EINA_TRUE;
2067 g_screenshot->auto_rotation = EINA_FALSE;
2069 tizen_screenshooter_set_oneshot_auto_rotation(_eflutil.wl.shot.tz_screenshooter, g_screenshot->auto_rotation);
2071 return EFL_UTIL_ERROR_NONE;
2075 efl_util_screenshot_get_auto_rotation(efl_util_screenshot_h screenshot, int *set)
2077 if (!screenshot || (screenshot != g_screenshot) || !set)
2078 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2080 *set = g_screenshot->auto_rotation;
2082 return EFL_UTIL_ERROR_NONE;
2085 /* LCOV_EXCL_START */
2086 struct _efl_util_screenmirror_h
2088 struct tizen_screenmirror *tz_screenmirror;
2094 Eina_List *buffer_list;
2096 Eina_Bool mirror_working;
2099 Eina_Bool cb_content;
2100 efl_util_screenmirror_handler user_func;
2104 typedef struct _efl_util_mirror_buffer efl_util_mirror_buffer;
2105 struct _efl_util_mirror_buffer
2107 struct wl_buffer *buffer;
2109 tbm_surface_h t_surface;
2112 static efl_util_screenmirror_h g_screenmirror;
2115 _efl_util_screenmirror_loop(void *data)
2117 efl_util_screenmirror_h screenmirror;
2120 screenmirror = (efl_util_screenmirror_h)data;
2124 if (!screenmirror->mirror_working)
2127 ret = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
2130 fprintf(stderr, "[screenmirror] fail: dispatch_queue\n");
2138 static efl_util_mirror_buffer *
2139 _efl_util_create_mirror_buffer(efl_util_screenmirror_h screenmirror)
2141 efl_util_mirror_buffer *mbuffer;
2143 mbuffer = calloc(1, sizeof(struct _efl_util_mirror_buffer));
2144 EINA_SAFETY_ON_NULL_RETURN_VAL(mbuffer, NULL);
2146 mbuffer->w = screenmirror->width;
2147 mbuffer->h = screenmirror->height;
2149 mbuffer->t_surface = tbm_surface_internal_create_with_flags(mbuffer->w,
2150 mbuffer->h, TBM_FORMAT_ARGB8888, TBM_BO_SCANOUT);
2151 EINA_SAFETY_ON_NULL_GOTO(mbuffer->t_surface, fail_create_surface);
2153 mbuffer->buffer = wayland_tbm_client_create_buffer(_eflutil.wl.shot.tbm_client, mbuffer->t_surface);
2154 EINA_SAFETY_ON_NULL_GOTO(mbuffer->buffer, fail_create_buffer);
2159 tbm_surface_destroy(mbuffer->t_surface);
2160 fail_create_surface:
2167 _efl_util_destroy_mirror_buffer(efl_util_mirror_buffer *mbuffer)
2169 EINA_SAFETY_ON_NULL_RETURN(mbuffer);
2171 if (mbuffer->buffer)
2172 wl_buffer_destroy(mbuffer->buffer);
2178 _efl_util_screenmirror_handle_dequeued(void *data,
2179 struct tizen_screenmirror *tz_screenmirror, struct wl_buffer *buffer)
2181 efl_util_screenmirror_h screenmirror;
2182 efl_util_mirror_buffer *mbuffer;
2185 screenmirror = (efl_util_screenmirror_h)data;
2186 screenmirror->cb_start = EINA_TRUE;
2188 EINA_LIST_FOREACH_SAFE(screenmirror->buffer_list, l, ll, mbuffer)
2190 if (mbuffer->buffer == buffer)
2192 if (mbuffer->w != screenmirror->width || mbuffer->h != screenmirror->height ||
2193 !screenmirror->mirror_working)
2194 tbm_surface_destroy(mbuffer->t_surface);
2196 screenmirror->user_func(screenmirror, mbuffer->t_surface, screenmirror->user_data);
2198 screenmirror->buffer_list = eina_list_remove_list(screenmirror->buffer_list, l);
2199 _efl_util_destroy_mirror_buffer(mbuffer);
2205 mbuffer = _efl_util_create_mirror_buffer(screenmirror);
2206 if (mbuffer == NULL)
2208 fprintf(stderr, "[screenmirror] fail: buffer create\n");
2211 screenmirror->buffer_list = eina_list_append(screenmirror->buffer_list, mbuffer);
2212 tizen_screenmirror_queue(screenmirror->tz_screenmirror, mbuffer->buffer);
2216 _efl_util_screenmirror_handle_content(void *data,
2217 struct tizen_screenmirror *tz_screenmirror, uint32_t content)
2219 efl_util_screenmirror_h screenmirror = NULL;
2221 screenmirror = (efl_util_screenmirror_h)data;
2222 screenmirror->cb_content = EINA_TRUE;
2226 _efl_util_screenmirror_handle_stop(void *data, struct tizen_screenmirror *tz_screenmirror)
2228 efl_util_screenmirror_h screenmirror = NULL;
2230 screenmirror = (efl_util_screenmirror_h)data;
2231 screenmirror->cb_stop = EINA_TRUE;
2234 static const struct tizen_screenmirror_listener efl_util_screenmirror_listener = {
2235 _efl_util_screenmirror_handle_dequeued,
2236 _efl_util_screenmirror_handle_content,
2237 _efl_util_screenmirror_handle_stop
2240 API efl_util_screenmirror_h
2241 efl_util_screenmirror_initialize(int width, int height)
2243 efl_util_screenmirror_h screenmirror = NULL;
2244 efl_util_mirror_buffer *mbuffer;
2245 Efl_Util_Wl_Output_Info *output;
2248 if (width <= 0 || height <= 0)
2250 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
2254 _screenshot_mutex_lock();
2258 if (g_screenmirror->mirror_working)
2260 set_last_result(EFL_UTIL_ERROR_INVALID_OPERATION);
2261 _screenshot_mutex_unlock();
2266 g_screenmirror->width = width;
2267 g_screenmirror->height = height;
2268 set_last_result(EFL_UTIL_ERROR_NONE);
2269 _screenshot_mutex_unlock();
2270 return g_screenmirror;
2274 screenmirror = calloc(1, sizeof(struct _efl_util_screenmirror_h));
2275 if (screenmirror == NULL)
2277 set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY);
2278 _screenshot_mutex_unlock();
2282 if (!_eflutil.wl.shot.tz_screenshooter)
2284 if (_efl_util_wl_screenshooter_init() == EINA_FALSE)
2286 if (_eflutil.wl.shot.noti == 0)
2287 set_last_result(EFL_UTIL_ERROR_PERMISSION_DENIED);
2289 set_last_result(EFL_UTIL_ERROR_SCREENSHOT_INIT_FAIL);
2295 output = eina_list_nth(_eflutil.wl.shot.output_list, 0);
2298 set_last_result(EFL_UTIL_ERROR_NO_RESOURCE_AVAILABLE);
2299 fprintf(stderr, "[screenmirror] fail: no output for screenmirror\n");
2300 goto fail_get_output;
2303 screenmirror->tz_screenmirror = tizen_screenshooter_get_screenmirror(_eflutil.wl.shot.tz_screenshooter, output->output);
2304 wl_proxy_set_queue((struct wl_proxy *)screenmirror->tz_screenmirror, _eflutil.wl.shot.queue);
2305 tizen_screenmirror_add_listener(screenmirror->tz_screenmirror, &efl_util_screenmirror_listener, screenmirror);
2306 tizen_screenmirror_set_stretch(screenmirror->tz_screenmirror, TIZEN_SCREENMIRROR_STRETCH_KEEP_RATIO);
2307 screenmirror->width = width;
2308 screenmirror->height = height;
2310 g_screenmirror = screenmirror;
2312 for (i = 0; i < 1; i++)
2314 mbuffer = _efl_util_create_mirror_buffer(screenmirror);
2317 screenmirror->buffer_list = eina_list_append(screenmirror->buffer_list, mbuffer);
2318 tizen_screenmirror_queue(screenmirror->tz_screenmirror, mbuffer->buffer);
2321 fprintf(stderr, "[screenmirror] fail: buffer create %d\n", i);
2323 while (!screenmirror->cb_content && ret != -1)
2324 ret = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
2326 _screenshot_mutex_unlock();
2328 return screenmirror;
2333 _screenshot_mutex_unlock();
2338 efl_util_screenmirror_deinitialize(efl_util_screenmirror_h screenmirror)
2340 efl_util_mirror_buffer *mbuffer;
2343 _screenshot_mutex_lock();
2345 if (!screenmirror || (screenmirror != g_screenmirror))
2347 _screenshot_mutex_unlock();
2348 _screenshot_mutex_destory();
2349 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2352 if (screenmirror->mirror_working)
2354 fprintf(stderr, "[screenmirror] fail: execute stop before deinit\n");
2355 _screenshot_mutex_unlock();
2356 _screenshot_mutex_destory();
2357 return EFL_UTIL_ERROR_INVALID_OPERATION;
2360 EINA_LIST_FOREACH(screenmirror->buffer_list, l, mbuffer)
2362 tbm_surface_destroy(mbuffer->t_surface);
2363 _efl_util_destroy_mirror_buffer(mbuffer);
2365 eina_list_free(screenmirror->buffer_list);
2367 tizen_screenmirror_destroy(screenmirror->tz_screenmirror);
2369 g_screenmirror = NULL;
2371 _efl_util_wl_screenshooter_deinit();
2373 _screenshot_mutex_unlock();
2374 _screenshot_mutex_destory();
2376 return EFL_UTIL_ERROR_NONE;
2380 efl_util_screenmirror_set_handler(efl_util_screenmirror_h screenmirror,
2381 efl_util_screenmirror_handler func, void *data)
2383 _screenshot_mutex_lock();
2385 if (!screenmirror || (screenmirror != g_screenmirror) || !func)
2387 _screenshot_mutex_unlock();
2388 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2390 screenmirror->user_func = func;
2391 screenmirror->user_data = data;
2393 _screenshot_mutex_unlock();
2395 return EFL_UTIL_ERROR_NONE;
2399 efl_util_screenmirror_start(efl_util_screenmirror_h screenmirror)
2403 _screenshot_mutex_lock();
2405 if (!screenmirror || (screenmirror != g_screenmirror))
2407 _screenshot_mutex_unlock();
2408 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2410 else if (!screenmirror->user_func)
2412 _screenshot_mutex_unlock();
2413 return EFL_UTIL_ERROR_SCREENSHOT_EXECUTION_FAIL;
2415 else if (screenmirror->mirror_working)
2417 _screenshot_mutex_unlock();
2418 return EFL_UTIL_ERROR_NONE;
2421 screenmirror->cb_start = EINA_FALSE;
2422 screenmirror->mirror_working = EINA_TRUE;
2423 tizen_screenmirror_start(screenmirror->tz_screenmirror);
2424 while (!screenmirror->cb_start && ret != -1)
2425 ret = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
2428 fprintf(stderr, "[screenmirror] fail: tizen_screenmirror_start\n");
2429 _screenshot_mutex_unlock();
2430 return EFL_UTIL_ERROR_SCREENSHOT_EXECUTION_FAIL;
2433 ret = pthread_create(&screenmirror->thread, NULL, _efl_util_screenmirror_loop, screenmirror);
2436 fprintf(stderr, "[screenmirror] fail: thread create fail\n");
2437 _screenshot_mutex_unlock();
2438 return EFL_UTIL_ERROR_SCREENSHOT_EXECUTION_FAIL;
2441 pthread_setname_np(screenmirror->thread, "e_util_mirror");
2443 _screenshot_mutex_unlock();
2445 return EFL_UTIL_ERROR_NONE;
2449 efl_util_screenmirror_stop(efl_util_screenmirror_h screenmirror)
2453 _screenshot_mutex_lock();
2455 if (!screenmirror || (screenmirror != g_screenmirror))
2457 _screenshot_mutex_unlock();
2458 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2460 else if (!screenmirror->mirror_working)
2462 _screenshot_mutex_unlock();
2463 return EFL_UTIL_ERROR_NONE;
2465 screenmirror->mirror_working = EINA_FALSE;
2466 pthread_join(screenmirror->thread, NULL);
2467 tizen_screenmirror_stop(screenmirror->tz_screenmirror);
2468 screenmirror->cb_stop = EINA_FALSE;
2470 while (!screenmirror->cb_stop && ret != -1)
2471 ret = wl_display_dispatch_queue(_eflutil.wl.dpy, _eflutil.wl.shot.queue);
2474 fprintf(stderr, "[screenmirror] fail: tizen_screenmirror_stop\n");
2475 _screenshot_mutex_unlock();
2476 return EFL_UTIL_ERROR_SCREENSHOT_EXECUTION_FAIL;
2479 _screenshot_mutex_unlock();
2481 return EFL_UTIL_ERROR_NONE;
2483 /* LCOV_EXCL_STOP */
2485 struct _efl_util_gesture_h
2490 API int EFL_UTIL_EVENT_GESTURE_EDGE_SWIPE = 0;
2491 API int EFL_UTIL_EVENT_GESTURE_EDGE_DRAG = 0;
2492 API int EFL_UTIL_EVENT_GESTURE_TAP = 0;
2493 API int EFL_UTIL_EVENT_GESTURE_PALM_COVER = 0;
2495 /* LCOV_EXCL_START */
2497 _cb_gesture_edge_swipe_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t fingers EINA_UNUSED, uint32_t edge EINA_UNUSED, uint32_t edge_size EINA_UNUSED, uint32_t start_point EINA_UNUSED, uint32_t end_point EINA_UNUSED, uint32_t error)
2499 _eflutil_defaultqueue.wl.gesture.request_notified = error;
2503 _cb_gesture_edge_swipe(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t mode, uint32_t fingers, int sx, int sy, uint32_t edge)
2505 efl_util_event_gesture_edge_swipe_s *ev = NULL;
2507 ev = (efl_util_event_gesture_edge_swipe_s *)calloc(1, sizeof(*ev));
2512 ev->fingers = fingers;
2517 ecore_event_add(EFL_UTIL_EVENT_GESTURE_EDGE_SWIPE, ev, NULL, NULL);
2521 _cb_gesture_edge_drag_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t fingers EINA_UNUSED, uint32_t edge EINA_UNUSED, uint32_t edge_size EINA_UNUSED, uint32_t start_point EINA_UNUSED, uint32_t end_point EINA_UNUSED, uint32_t error)
2523 _eflutil_defaultqueue.wl.gesture.request_notified = error;
2527 _cb_gesture_edge_drag(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t mode, uint32_t fingers, int cx, int cy, uint32_t edge)
2529 efl_util_event_gesture_edge_drag_s *ev = NULL;
2531 ev = (efl_util_event_gesture_edge_drag_s *)calloc(1, sizeof(*ev));
2536 ev->fingers = fingers;
2541 ecore_event_add(EFL_UTIL_EVENT_GESTURE_EDGE_DRAG, ev, NULL, NULL);
2545 _cb_gesture_tap_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t fingers EINA_UNUSED, uint32_t repeat EINA_UNUSED, uint32_t error)
2547 _eflutil_defaultqueue.wl.gesture.request_notified = error;
2551 _cb_gesture_tap(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, uint32_t mode, uint32_t fingers, uint32_t repeats)
2553 efl_util_event_gesture_tap_s *ev = NULL;
2555 ev = (efl_util_event_gesture_tap_s *)calloc(1, sizeof(*ev));
2560 ev->fingers = fingers;
2561 ev->repeats = repeats;
2563 ecore_event_add(EFL_UTIL_EVENT_GESTURE_TAP, ev, NULL, NULL);
2565 /* LCOV_EXCL_STOP */
2568 _cb_gesture_palm_cover_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, struct wl_surface *surface EINA_UNUSED, uint32_t error)
2570 _eflutil_defaultqueue.wl.gesture.request_notified = error;
2573 /* LCOV_EXCL_START */
2575 _cb_gesture_palm_cover(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, struct wl_surface *surface, uint32_t mode, uint32_t duration, int cx, int cy, uint32_t size, wl_fixed_t pressure)
2577 efl_util_event_gesture_palm_cover_s *ev = NULL;
2579 ev = (efl_util_event_gesture_palm_cover_s *)calloc(1, sizeof(*ev));
2584 ev->duration = duration;
2588 ev->pressure = wl_fixed_to_int(pressure);
2590 ecore_event_add(EFL_UTIL_EVENT_GESTURE_PALM_COVER, ev, NULL, NULL);
2592 /* LCOV_EXCL_STOP */
2595 _cb_gesture_activate_notify(void *data EINA_UNUSED, struct tizen_gesture *tizen_gesture EINA_UNUSED, struct wl_surface *surface EINA_UNUSED, uint32_t type EINA_UNUSED, uint32_t active EINA_UNUSED, uint32_t error)
2597 _eflutil_defaultqueue.wl.gesture.request_notified = error;
2600 static efl_util_error_e
2601 _efl_util_gesture_convert_error(int ret)
2605 case TIZEN_GESTURE_ERROR_NONE:
2606 return EFL_UTIL_ERROR_NONE;
2607 case TIZEN_GESTURE_ERROR_INVALID_DATA:
2608 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2609 case TIZEN_GESTURE_ERROR_NO_PERMISSION:
2610 return EFL_UTIL_ERROR_PERMISSION_DENIED;
2611 case TIZEN_GESTURE_ERROR_NO_SYSTEM_RESOURCES:
2612 return EFL_UTIL_ERROR_OUT_OF_MEMORY;
2613 case TIZEN_GESTURE_ERROR_GRABBED_ALREADY:
2614 return EFL_UTIL_ERROR_NO_RESOURCE_AVAILABLE;
2615 case TIZEN_GESTURE_ERROR_NOT_SUPPORTED:
2616 return EFL_UTIL_ERROR_NOT_SUPPORTED;
2618 return EFL_UTIL_ERROR_NONE;
2622 /* LCOV_EXCL_START */
2623 static efl_util_error_e
2624 _efl_util_gesture_verify_request_notified()
2626 int ret = EFL_UTIL_ERROR_NONE;
2628 while (_eflutil_defaultqueue.wl.gesture.request_notified == -1)
2629 wl_display_dispatch(_eflutil_defaultqueue.wl.dpy);
2631 ret = _efl_util_gesture_convert_error(_eflutil_defaultqueue.wl.gesture.request_notified);
2632 _eflutil_defaultqueue.wl.gesture.request_notified = -1;
2638 _efl_util_gesture_grab_edge_swipe(efl_util_gesture_data data, Eina_Bool grabbed)
2640 int ret = EFL_UTIL_ERROR_NONE;
2641 Efl_Util_Gesture_Common_Grab_Data *base_data = NULL;
2642 Efl_Util_Gesture_Edge_Swipe_Grab_Data *edge_swipe_data = NULL;
2643 unsigned int fingers = 0;
2644 unsigned int edge = 0;
2645 unsigned int edge_size = 0;
2646 unsigned int start_point = 0;
2647 unsigned int end_point = 0;
2649 base_data = (Efl_Util_Gesture_Common_Grab_Data *)data;
2651 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil_defaultqueue.wl.gesture.proto, EFL_UTIL_ERROR_INVALID_PARAMETER);
2652 EINA_SAFETY_ON_NULL_RETURN_VAL(base_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
2653 EINA_SAFETY_ON_FALSE_RETURN_VAL(base_data->type == TIZEN_GESTURE_TYPE_EDGE_SWIPE,
2654 EFL_UTIL_ERROR_INVALID_PARAMETER);
2656 edge_swipe_data = (Efl_Util_Gesture_Edge_Swipe_Grab_Data *)data;
2658 fingers = edge_swipe_data->fingers;
2659 edge = edge_swipe_data->edge;
2660 edge_size = edge_swipe_data->edge_size;
2661 start_point = edge_swipe_data->start_point;
2662 end_point = edge_swipe_data->end_point;
2665 tizen_gesture_grab_edge_swipe(_eflutil_defaultqueue.wl.gesture.proto, fingers, edge, edge_size, start_point, end_point);
2667 tizen_gesture_ungrab_edge_swipe(_eflutil_defaultqueue.wl.gesture.proto, fingers, edge, edge_size, start_point, end_point);
2669 ret = _efl_util_gesture_verify_request_notified();
2675 _efl_util_gesture_grab_edge_drag(efl_util_gesture_data data, Eina_Bool grabbed)
2677 int ret = EFL_UTIL_ERROR_NONE;
2678 Efl_Util_Gesture_Common_Grab_Data *base_data = NULL;
2679 Efl_Util_Gesture_Edge_Drag_Grab_Data *edge_drag_data = NULL;
2680 unsigned int fingers = 0;
2681 unsigned int edge = 0;
2682 unsigned int edge_size = 0;
2683 unsigned int start_point = 0;
2684 unsigned int end_point = 0;
2686 base_data = (Efl_Util_Gesture_Common_Grab_Data *)data;
2688 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil_defaultqueue.wl.gesture.proto, EFL_UTIL_ERROR_INVALID_PARAMETER);
2689 EINA_SAFETY_ON_NULL_RETURN_VAL(base_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
2690 EINA_SAFETY_ON_FALSE_RETURN_VAL(base_data->type == TIZEN_GESTURE_TYPE_EDGE_DRAG,
2691 EFL_UTIL_ERROR_INVALID_PARAMETER);
2693 edge_drag_data = (Efl_Util_Gesture_Edge_Drag_Grab_Data *)data;
2695 fingers = edge_drag_data->fingers;
2696 edge = edge_drag_data->edge;
2697 edge_size = edge_drag_data->edge_size;
2698 start_point = edge_drag_data->start_point;
2699 end_point = edge_drag_data->end_point;
2702 tizen_gesture_grab_edge_drag(_eflutil_defaultqueue.wl.gesture.proto, fingers, edge, edge_size, start_point, end_point);
2704 tizen_gesture_ungrab_edge_drag(_eflutil_defaultqueue.wl.gesture.proto, fingers, edge, edge_size, start_point, end_point);
2706 ret = _efl_util_gesture_verify_request_notified();
2712 _efl_util_gesture_grab_tap(efl_util_gesture_data data, Eina_Bool grabbed)
2714 int ret = EFL_UTIL_ERROR_NONE;
2715 Efl_Util_Gesture_Common_Grab_Data *base_data = NULL;
2716 Efl_Util_Gesture_Tap_Grab_Data *tap_data = NULL;
2717 unsigned int fingers = 0;
2718 unsigned int repeats = 0;
2720 base_data = (Efl_Util_Gesture_Common_Grab_Data *)data;
2722 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil_defaultqueue.wl.gesture.proto, EFL_UTIL_ERROR_INVALID_PARAMETER);
2723 EINA_SAFETY_ON_NULL_RETURN_VAL(base_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
2724 EINA_SAFETY_ON_FALSE_RETURN_VAL(base_data->type == TIZEN_GESTURE_TYPE_TAP,
2725 EFL_UTIL_ERROR_INVALID_PARAMETER);
2727 tap_data = (Efl_Util_Gesture_Tap_Grab_Data *)data;
2729 fingers = tap_data->fingers;
2730 repeats = tap_data->repeats;
2733 tizen_gesture_grab_tap(_eflutil_defaultqueue.wl.gesture.proto, fingers, repeats);
2735 tizen_gesture_ungrab_tap(_eflutil_defaultqueue.wl.gesture.proto, fingers, repeats);
2737 ret = _efl_util_gesture_verify_request_notified();
2743 _efl_util_gesture_grab_palm_cover(efl_util_gesture_data data, Eina_Bool grabbed)
2745 int ret = EFL_UTIL_ERROR_NONE;
2746 Efl_Util_Gesture_Common_Grab_Data *base_data = NULL;
2748 base_data = (Efl_Util_Gesture_Common_Grab_Data *)data;
2750 EINA_SAFETY_ON_NULL_RETURN_VAL(_eflutil_defaultqueue.wl.gesture.proto, EFL_UTIL_ERROR_INVALID_PARAMETER);
2751 EINA_SAFETY_ON_NULL_RETURN_VAL(base_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
2752 EINA_SAFETY_ON_FALSE_RETURN_VAL(base_data->type == TIZEN_GESTURE_TYPE_PALM_COVER,
2753 EFL_UTIL_ERROR_INVALID_PARAMETER);
2756 tizen_gesture_grab_palm_cover(_eflutil_defaultqueue.wl.gesture.proto);
2758 tizen_gesture_ungrab_palm_cover(_eflutil_defaultqueue.wl.gesture.proto);
2760 ret = _efl_util_gesture_verify_request_notified();
2764 /* LCOV_EXCL_STOP */
2766 API efl_util_gesture_h
2767 efl_util_gesture_initialize(void)
2769 efl_util_gesture_h gesture_h = NULL;
2771 gesture_h = (efl_util_gesture_h)calloc(1, sizeof(struct _efl_util_gesture_h));
2774 set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY); /* LCOV_EXCL_LINE */
2775 goto out; /* LCOV_EXCL_LINE */
2778 if (_wl_init_default_queue() == (int)EINA_FALSE)
2780 set_last_result(EFL_UTIL_ERROR_NOT_SUPPORTED); /* LCOV_EXCL_LINE */
2781 goto out; /* LCOV_EXCL_LINE */
2784 while (!_eflutil_defaultqueue.wl.gesture.proto)
2785 wl_display_dispatch(_eflutil_defaultqueue.wl.dpy); /* LCOV_EXCL_LINE */
2787 if (_eflutil_defaultqueue.wl.gesture.event_init <= 0)
2789 if (ecore_event_init() <= 0)
2791 set_last_result(EFL_UTIL_ERROR_NOT_SUPPORTED); /* LCOV_EXCL_LINE */
2792 goto out; /* LCOV_EXCL_LINE */
2794 EFL_UTIL_EVENT_GESTURE_EDGE_SWIPE = ecore_event_type_new();
2795 EFL_UTIL_EVENT_GESTURE_EDGE_DRAG = ecore_event_type_new();
2796 EFL_UTIL_EVENT_GESTURE_TAP = ecore_event_type_new();
2797 EFL_UTIL_EVENT_GESTURE_PALM_COVER = ecore_event_type_new();
2799 _eflutil_defaultqueue.wl.gesture.event_init++;
2800 gesture_h->init = EINA_TRUE;
2802 set_last_result(EFL_UTIL_ERROR_NONE);
2806 /* LCOV_EXCL_START */
2813 /* LCOV_EXCL_STOP */
2817 efl_util_gesture_deinitialize(efl_util_gesture_h gesture_h)
2819 EINA_SAFETY_ON_NULL_RETURN_VAL(gesture_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
2820 EINA_SAFETY_ON_FALSE_RETURN_VAL(gesture_h->init, EFL_UTIL_ERROR_INVALID_PARAMETER);
2825 _eflutil_defaultqueue.wl.gesture.event_init--;
2827 if (_eflutil_defaultqueue.wl.gesture.event_init <= 0)
2829 _eflutil_defaultqueue.wl.gesture.event_init = 0;
2830 ecore_event_shutdown();
2831 EFL_UTIL_EVENT_GESTURE_EDGE_SWIPE = 0;
2832 EFL_UTIL_EVENT_GESTURE_EDGE_DRAG = 0;
2833 EFL_UTIL_EVENT_GESTURE_TAP = 0;
2834 EFL_UTIL_EVENT_GESTURE_PALM_COVER = 0;
2837 return EFL_UTIL_ERROR_NONE;
2840 API efl_util_gesture_data
2841 efl_util_gesture_edge_swipe_new(efl_util_gesture_h gesture_h, unsigned int fingers, efl_util_gesture_edge_e edge)
2843 Efl_Util_Gesture_Edge_Swipe_Grab_Data *data;
2845 if (!gesture_h || gesture_h->init == EINA_FALSE)
2847 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
2851 if (edge <= EFL_UTIL_GESTURE_EDGE_NONE || edge > EFL_UTIL_GESTURE_EDGE_LEFT)
2853 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
2857 data = (Efl_Util_Gesture_Edge_Swipe_Grab_Data *)calloc(1, sizeof(Efl_Util_Gesture_Edge_Swipe_Grab_Data));
2860 set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY); /* LCOV_EXCL_LINE */
2861 return NULL; /* LCOV_EXCL_LINE */
2864 data->base.type = TIZEN_GESTURE_TYPE_EDGE_SWIPE;
2865 data->fingers = fingers;
2867 data->edge_size = EFL_UTIL_GESTURE_EDGE_SIZE_FULL;
2869 set_last_result(EFL_UTIL_ERROR_NONE);
2871 return (void *)data;
2875 efl_util_gesture_edge_swipe_free(efl_util_gesture_h gesture_h, efl_util_gesture_data data)
2877 if (!gesture_h || gesture_h->init == EINA_FALSE)
2879 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2884 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2890 return EFL_UTIL_ERROR_NONE;
2894 efl_util_gesture_edge_swipe_size_set(efl_util_gesture_data data, efl_util_gesture_edge_size_e edge_size, unsigned int start_point, unsigned int end_point)
2896 Efl_Util_Gesture_Edge_Swipe_Grab_Data *edge_swipe_data = data;
2898 EINA_SAFETY_ON_NULL_RETURN_VAL(edge_swipe_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
2899 EINA_SAFETY_ON_FALSE_RETURN_VAL(edge_swipe_data->base.type == TIZEN_GESTURE_TYPE_EDGE_SWIPE,
2900 EFL_UTIL_ERROR_INVALID_PARAMETER);
2901 EINA_SAFETY_ON_FALSE_RETURN_VAL(edge_size == EFL_UTIL_GESTURE_EDGE_SIZE_PARTIAL,
2902 EFL_UTIL_ERROR_INVALID_PARAMETER);
2903 EINA_SAFETY_ON_FALSE_RETURN_VAL(end_point > start_point, EFL_UTIL_ERROR_INVALID_PARAMETER);
2905 edge_swipe_data->edge_size = edge_size;
2906 edge_swipe_data->start_point = start_point;
2907 edge_swipe_data->end_point = end_point;
2909 return EFL_UTIL_ERROR_NONE;
2912 API efl_util_gesture_data
2913 efl_util_gesture_edge_drag_new(efl_util_gesture_h gesture_h, unsigned int fingers, efl_util_gesture_edge_e edge)
2915 Efl_Util_Gesture_Edge_Drag_Grab_Data *data;
2917 if (!gesture_h || gesture_h->init == EINA_FALSE)
2919 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
2923 if (edge <= EFL_UTIL_GESTURE_EDGE_NONE || edge > EFL_UTIL_GESTURE_EDGE_LEFT)
2925 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
2929 data = (Efl_Util_Gesture_Edge_Drag_Grab_Data *)calloc(1, sizeof(Efl_Util_Gesture_Edge_Drag_Grab_Data));
2932 set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY); /* LCOV_EXCL_LINE */
2933 return NULL; /* LCOV_EXCL_LINE */
2936 data->base.type = TIZEN_GESTURE_TYPE_EDGE_DRAG;
2937 data->fingers = fingers;
2939 data->edge_size = EFL_UTIL_GESTURE_EDGE_SIZE_FULL;
2941 set_last_result(EFL_UTIL_ERROR_NONE);
2943 return (void *)data;
2947 efl_util_gesture_edge_drag_free(efl_util_gesture_h gesture_h, efl_util_gesture_data data)
2949 if (!gesture_h || gesture_h->init == EINA_FALSE)
2951 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2956 return EFL_UTIL_ERROR_INVALID_PARAMETER;
2962 return EFL_UTIL_ERROR_NONE;
2966 efl_util_gesture_edge_drag_size_set(efl_util_gesture_data data, efl_util_gesture_edge_size_e edge_size, unsigned int start_point, unsigned int end_point)
2968 Efl_Util_Gesture_Edge_Drag_Grab_Data *edge_drag_data = data;
2970 EINA_SAFETY_ON_NULL_RETURN_VAL(edge_drag_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
2971 EINA_SAFETY_ON_FALSE_RETURN_VAL(edge_drag_data->base.type == TIZEN_GESTURE_TYPE_EDGE_DRAG,
2972 EFL_UTIL_ERROR_INVALID_PARAMETER);
2973 EINA_SAFETY_ON_FALSE_RETURN_VAL(edge_size == EFL_UTIL_GESTURE_EDGE_SIZE_PARTIAL,
2974 EFL_UTIL_ERROR_INVALID_PARAMETER);
2975 EINA_SAFETY_ON_FALSE_RETURN_VAL(end_point > start_point, EFL_UTIL_ERROR_INVALID_PARAMETER);
2977 edge_drag_data->edge_size = edge_size;
2978 edge_drag_data->start_point = start_point;
2979 edge_drag_data->end_point = end_point;
2981 return EFL_UTIL_ERROR_NONE;
2984 API efl_util_gesture_data
2985 efl_util_gesture_tap_new(efl_util_gesture_h gesture_h, unsigned int fingers, unsigned int repeats)
2987 Efl_Util_Gesture_Tap_Grab_Data *data;
2989 if (!gesture_h || gesture_h->init == EINA_FALSE)
2991 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
2995 if (fingers <= 1 || repeats <= 1)
2997 set_last_result(EFL_UTIL_ERROR_NOT_SUPPORTED);
3001 data = (Efl_Util_Gesture_Tap_Grab_Data *)calloc(1, sizeof(Efl_Util_Gesture_Tap_Grab_Data));
3004 set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY); /* LCOV_EXCL_LINE */
3005 return NULL; /* LCOV_EXCL_LINE */
3008 data->base.type = TIZEN_GESTURE_TYPE_TAP;
3009 data->fingers = fingers;
3010 data->repeats = repeats;
3012 set_last_result(EFL_UTIL_ERROR_NONE);
3014 return (void *)data;
3018 efl_util_gesture_tap_free(efl_util_gesture_h gesture_h, efl_util_gesture_data data)
3020 if (!gesture_h || gesture_h->init == EINA_FALSE)
3022 return EFL_UTIL_ERROR_INVALID_PARAMETER;
3027 return EFL_UTIL_ERROR_INVALID_PARAMETER;
3033 return EFL_UTIL_ERROR_NONE;
3036 API efl_util_gesture_data
3037 efl_util_gesture_palm_cover_new(efl_util_gesture_h gesture_h)
3039 Efl_Util_Gesture_Palm_Cover_Grab_Data *data;
3041 if (!gesture_h || gesture_h->init == EINA_FALSE)
3043 set_last_result(EFL_UTIL_ERROR_INVALID_PARAMETER);
3047 data = (Efl_Util_Gesture_Palm_Cover_Grab_Data *)calloc(1, sizeof(Efl_Util_Gesture_Palm_Cover_Grab_Data));
3050 set_last_result(EFL_UTIL_ERROR_OUT_OF_MEMORY); /* LCOV_EXCL_LINE */
3051 return NULL; /* LCOV_EXCL_LINE */
3054 data->base.type = TIZEN_GESTURE_TYPE_PALM_COVER;
3056 set_last_result(EFL_UTIL_ERROR_NONE);
3058 return (void *)data;
3062 efl_util_gesture_palm_cover_free(efl_util_gesture_h gesture_h, efl_util_gesture_data data)
3064 if (!gesture_h || gesture_h->init == EINA_FALSE)
3066 return EFL_UTIL_ERROR_INVALID_PARAMETER;
3071 return EFL_UTIL_ERROR_INVALID_PARAMETER;
3077 return EFL_UTIL_ERROR_NONE;
3080 /* LCOV_EXCL_START */
3082 efl_util_gesture_grab(efl_util_gesture_h gesture_h, efl_util_gesture_data data)
3084 int ret = EFL_UTIL_ERROR_NONE;
3085 Efl_Util_Gesture_Common_Grab_Data *base_data = NULL;
3087 base_data = (Efl_Util_Gesture_Common_Grab_Data *)data;
3089 EINA_SAFETY_ON_NULL_RETURN_VAL(gesture_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
3090 EINA_SAFETY_ON_FALSE_RETURN_VAL(gesture_h->init, EFL_UTIL_ERROR_INVALID_PARAMETER);
3091 EINA_SAFETY_ON_NULL_RETURN_VAL(base_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
3093 switch (base_data->type)
3095 case TIZEN_GESTURE_TYPE_EDGE_SWIPE:
3096 ret = _efl_util_gesture_grab_edge_swipe(data, EINA_TRUE);
3098 case TIZEN_GESTURE_TYPE_EDGE_DRAG:
3099 ret = _efl_util_gesture_grab_edge_drag(data, EINA_TRUE);
3101 case TIZEN_GESTURE_TYPE_TAP:
3102 ret = _efl_util_gesture_grab_tap(data, EINA_TRUE);
3104 case TIZEN_GESTURE_TYPE_PALM_COVER:
3105 ret = _efl_util_gesture_grab_palm_cover(data, EINA_TRUE);
3108 return EFL_UTIL_ERROR_INVALID_PARAMETER;
3115 efl_util_gesture_ungrab(efl_util_gesture_h gesture_h, efl_util_gesture_data data)
3117 int ret = EFL_UTIL_ERROR_NONE;
3118 Efl_Util_Gesture_Common_Grab_Data *base_data = NULL;
3120 base_data = (Efl_Util_Gesture_Common_Grab_Data *)data;
3122 EINA_SAFETY_ON_NULL_RETURN_VAL(gesture_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
3123 EINA_SAFETY_ON_FALSE_RETURN_VAL(gesture_h->init, EFL_UTIL_ERROR_INVALID_PARAMETER);
3124 EINA_SAFETY_ON_NULL_RETURN_VAL(base_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
3126 switch (base_data->type)
3128 case TIZEN_GESTURE_TYPE_EDGE_SWIPE:
3129 ret = _efl_util_gesture_grab_edge_swipe(data, EINA_FALSE);
3131 case TIZEN_GESTURE_TYPE_EDGE_DRAG:
3132 ret = _efl_util_gesture_grab_edge_drag(data, EINA_FALSE);
3134 case TIZEN_GESTURE_TYPE_TAP:
3135 ret = _efl_util_gesture_grab_tap(data, EINA_FALSE);
3137 case TIZEN_GESTURE_TYPE_PALM_COVER:
3138 ret = _efl_util_gesture_grab_palm_cover(data, EINA_FALSE);
3141 return EFL_UTIL_ERROR_INVALID_PARAMETER;
3146 /* LCOV_EXCL_STOP */
3149 efl_util_gesture_select(efl_util_gesture_h gesture_h, Evas_Object *window, efl_util_gesture_data data)
3151 Efl_Util_Gesture_Common_Grab_Data *base_data = NULL;
3152 Ecore_Wl2_Window *wlwin;
3153 struct wl_surface *surface;
3156 base_data = (Efl_Util_Gesture_Common_Grab_Data *)data;
3158 EINA_SAFETY_ON_NULL_RETURN_VAL(gesture_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
3159 EINA_SAFETY_ON_FALSE_RETURN_VAL(gesture_h->init, EFL_UTIL_ERROR_INVALID_PARAMETER);
3160 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
3161 EINA_SAFETY_ON_NULL_RETURN_VAL(base_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
3163 if (base_data->type != TIZEN_GESTURE_TYPE_PALM_COVER)
3164 return EFL_UTIL_ERROR_NOT_SUPPORTED;
3166 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
3167 if (!wlwin) return EFL_UTIL_ERROR_INVALID_PARAMETER;
3169 surface = ecore_wl2_window_surface_get(wlwin);
3170 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
3171 EFL_UTIL_ERROR_INVALID_PARAMETER);
3173 tizen_gesture_select_palm_cover(_eflutil_defaultqueue.wl.gesture.proto, surface);
3175 ret = _efl_util_gesture_verify_request_notified();
3181 efl_util_gesture_deselect(efl_util_gesture_h gesture_h, Evas_Object *window, efl_util_gesture_data data)
3183 Efl_Util_Gesture_Common_Grab_Data *base_data = NULL;
3184 Ecore_Wl2_Window *wlwin;
3185 struct wl_surface *surface;
3188 base_data = (Efl_Util_Gesture_Common_Grab_Data *)data;
3190 EINA_SAFETY_ON_NULL_RETURN_VAL(gesture_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
3191 EINA_SAFETY_ON_FALSE_RETURN_VAL(gesture_h->init, EFL_UTIL_ERROR_INVALID_PARAMETER);
3192 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
3193 EINA_SAFETY_ON_NULL_RETURN_VAL(base_data, EFL_UTIL_ERROR_INVALID_PARAMETER);
3195 if (base_data->type != TIZEN_GESTURE_TYPE_PALM_COVER)
3196 return EFL_UTIL_ERROR_NOT_SUPPORTED;
3198 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
3199 if (!wlwin) return EFL_UTIL_ERROR_INVALID_PARAMETER;
3201 surface = ecore_wl2_window_surface_get(wlwin);
3202 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
3203 EFL_UTIL_ERROR_INVALID_PARAMETER);
3205 tizen_gesture_deselect_palm_cover(_eflutil_defaultqueue.wl.gesture.proto, surface);
3207 ret = _efl_util_gesture_verify_request_notified();
3212 /* LCOV_EXCL_START */
3214 efl_util_gesture_activate_set(efl_util_gesture_h gesture_h, unsigned int type, Eina_Bool active)
3218 EINA_SAFETY_ON_NULL_RETURN_VAL(gesture_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
3219 EINA_SAFETY_ON_FALSE_RETURN_VAL(gesture_h->init, EFL_UTIL_ERROR_INVALID_PARAMETER);
3220 EINA_SAFETY_ON_TRUE_RETURN_VAL(type == EFL_UTIL_GESTURE_TYPE_NONE, EFL_UTIL_ERROR_INVALID_PARAMETER);
3222 tizen_gesture_activate_set(_eflutil_defaultqueue.wl.gesture.proto, NULL, type, active);
3224 ret = _efl_util_gesture_verify_request_notified();
3228 /* LCOV_EXCL_STOP */
3231 efl_util_gesture_activate_set_on_window(efl_util_gesture_h gesture_h, Evas_Object *window, unsigned int type, Eina_Bool active)
3233 Ecore_Wl2_Window *wlwin;
3234 struct wl_surface *surface;
3237 EINA_SAFETY_ON_NULL_RETURN_VAL(gesture_h, EFL_UTIL_ERROR_INVALID_PARAMETER);
3238 EINA_SAFETY_ON_FALSE_RETURN_VAL(gesture_h->init, EFL_UTIL_ERROR_INVALID_PARAMETER);
3239 EINA_SAFETY_ON_NULL_RETURN_VAL(window, EFL_UTIL_ERROR_INVALID_PARAMETER);
3240 EINA_SAFETY_ON_TRUE_RETURN_VAL(type == EFL_UTIL_GESTURE_TYPE_NONE, EFL_UTIL_ERROR_INVALID_PARAMETER);
3242 wlwin = (Ecore_Wl2_Window *)elm_win_wl_window_get(window);
3243 if (!wlwin) return EFL_UTIL_ERROR_INVALID_PARAMETER;
3245 surface = ecore_wl2_window_surface_get(wlwin);
3246 EINA_SAFETY_ON_NULL_RETURN_VAL(surface,
3247 EFL_UTIL_ERROR_INVALID_PARAMETER);
3249 tizen_gesture_activate_set(_eflutil_defaultqueue.wl.gesture.proto, surface, type, active);
3251 ret = _efl_util_gesture_verify_request_notified();