compositor: Remove weston_read_pixels functionality
[profile/ivi/weston.git] / src / compositor.h
1 /*
2  * Copyright © 2008-2011 Kristian Høgsberg
3  * Copyright © 2012 Collabora, Ltd.
4  *
5  * Permission to use, copy, modify, distribute, and sell this software and
6  * its documentation for any purpose is hereby granted without fee, provided
7  * that the above copyright notice appear in all copies and that both that
8  * copyright notice and this permission notice appear in supporting
9  * documentation, and that the name of the copyright holders not be used in
10  * advertising or publicity pertaining to distribution of the software
11  * without specific, written prior permission.  The copyright holders make
12  * no representations about the suitability of this software for any
13  * purpose.  It is provided "as is" without express or implied warranty.
14  *
15  * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
16  * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
17  * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
18  * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
19  * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
20  * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
21  * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
22  */
23
24 #ifndef _WAYLAND_SYSTEM_COMPOSITOR_H_
25 #define _WAYLAND_SYSTEM_COMPOSITOR_H_
26
27 #include <pixman.h>
28 #include <xkbcommon/xkbcommon.h>
29 #include <wayland-server.h>
30
31 #include <GLES2/gl2.h>
32 #include <GLES2/gl2ext.h>
33 #include <EGL/egl.h>
34 #include <EGL/eglext.h>
35
36 #include "matrix.h"
37 #include "../shared/config-parser.h"
38 #include "weston-egl-ext.h"
39
40
41 struct weston_transform {
42         struct weston_matrix matrix;
43         struct wl_list link;
44 };
45
46 struct weston_surface;
47 struct shell_surface;
48 struct weston_seat;
49 struct weston_output;
50
51 enum weston_keyboard_modifier {
52         MODIFIER_CTRL = (1 << 0),
53         MODIFIER_ALT = (1 << 1),
54         MODIFIER_SUPER = (1 << 2),
55 };
56
57 enum weston_led {
58         LED_NUM_LOCK = (1 << 0),
59         LED_CAPS_LOCK = (1 << 1),
60         LED_SCROLL_LOCK = (1 << 2),
61 };
62
63 struct weston_mode {
64         uint32_t flags;
65         int32_t width, height;
66         uint32_t refresh;
67         struct wl_list link;
68 };
69
70 struct weston_shell_client {
71         void (*send_configure)(struct weston_surface *surface,
72                                uint32_t edges, int32_t width, int32_t height);
73 };
74
75 struct weston_shell_interface {
76         void *shell;                    /* either desktop or tablet */
77
78         struct shell_surface *(*create_shell_surface)(void *shell,
79                                                       struct weston_surface *surface,
80                                                       const struct weston_shell_client *client);
81
82         void (*set_toplevel)(struct shell_surface *shsurf);
83
84         void (*set_transient)(struct shell_surface *shsurf,
85                               struct shell_surface *pshsurf,
86                               int x, int y, uint32_t flags);
87         int (*move)(struct shell_surface *shsurf, struct weston_seat *ws);
88         int (*resize)(struct shell_surface *shsurf,
89                       struct weston_seat *ws, uint32_t edges);
90
91 };
92
93 struct weston_border {
94         int32_t left, right, top, bottom;
95 };
96
97 struct weston_animation {
98         void (*frame)(struct weston_animation *animation,
99                       struct weston_output *output, uint32_t msecs);
100         int frame_counter;
101         struct wl_list link;
102 };
103
104 struct weston_spring {
105         double k;
106         double friction;
107         double current;
108         double target;
109         double previous;
110         uint32_t timestamp;
111 };
112
113 enum {
114         ZOOM_FOCUS_POINTER,
115         ZOOM_FOCUS_TEXT
116 };
117
118 struct weston_fixed_point {
119         wl_fixed_t x, y;
120 };
121
122 struct weston_output_zoom {
123         int active;
124         uint32_t type;
125         float increment;
126         float level;
127         float max_level;
128         float trans_x, trans_y;
129         struct weston_animation animation_z;
130         struct weston_spring spring_z;
131         struct weston_animation animation_xy;
132         struct weston_spring spring_xy;
133         struct weston_fixed_point from;
134         struct weston_fixed_point to;
135         struct weston_fixed_point current;
136         struct weston_fixed_point text_cursor;
137 };
138
139 /* bit compatible with drm definitions. */
140 enum dpms_enum {
141         WESTON_DPMS_ON,
142         WESTON_DPMS_STANDBY,
143         WESTON_DPMS_SUSPEND,
144         WESTON_DPMS_OFF
145 };
146
147 struct weston_output {
148         uint32_t id;
149
150         struct wl_list link;
151         struct wl_list resource_list;
152         struct wl_global *global;
153         struct weston_compositor *compositor;
154         struct weston_matrix matrix;
155         struct wl_list animation_list;
156         int32_t x, y, mm_width, mm_height;
157         struct weston_border border;
158         pixman_region32_t region;
159         pixman_region32_t previous_damage;
160         uint32_t flags;
161         int repaint_needed;
162         int repaint_scheduled;
163         struct weston_output_zoom zoom;
164         int dirty;
165         struct wl_signal frame_signal;
166         uint32_t frame_time;
167
168         char *make, *model;
169         uint32_t subpixel;
170         
171         struct weston_mode *current;
172         struct weston_mode *origin;
173         struct wl_list mode_list;
174
175         void (*repaint)(struct weston_output *output,
176                         pixman_region32_t *damage);
177         void (*destroy)(struct weston_output *output);
178         void (*assign_planes)(struct weston_output *output);
179         int (*switch_mode)(struct weston_output *output, struct weston_mode *mode);
180
181         /* backlight values are on 0-255 range, where higher is brighter */
182         uint32_t backlight_current;
183         void (*set_backlight)(struct weston_output *output, uint32_t value);
184         void (*set_dpms)(struct weston_output *output, enum dpms_enum level);
185 };
186
187 struct weston_xkb_info {
188         struct xkb_keymap *keymap;
189         int keymap_fd;
190         size_t keymap_size;
191         char *keymap_area;
192         xkb_mod_index_t ctrl_mod;
193         xkb_mod_index_t alt_mod;
194         xkb_mod_index_t super_mod;
195         xkb_led_index_t num_led;
196         xkb_led_index_t caps_led;
197         xkb_led_index_t scroll_led;
198 };
199
200 struct weston_seat {
201         struct wl_seat seat;
202         struct wl_pointer pointer;
203         int has_pointer;
204         struct wl_keyboard keyboard;
205         int has_keyboard;
206         struct wl_touch touch;
207         int has_touch;
208
209         struct weston_compositor *compositor;
210         struct weston_surface *sprite;
211         struct wl_listener sprite_destroy_listener;
212         struct weston_surface *drag_surface;
213         struct wl_listener drag_surface_destroy_listener;
214         int32_t hotspot_x, hotspot_y;
215         struct wl_list link;
216         enum weston_keyboard_modifier modifier_state;
217         struct wl_surface *saved_kbd_focus;
218         struct wl_listener saved_kbd_focus_listener;
219
220         uint32_t num_tp;
221         struct wl_surface *touch_focus;
222         struct wl_listener touch_focus_listener;
223         struct wl_resource *touch_focus_resource;
224         struct wl_listener touch_focus_resource_listener;
225
226         struct wl_listener new_drag_icon_listener;
227
228         void (*led_update)(struct weston_seat *ws, enum weston_led leds);
229
230         struct weston_xkb_info xkb_info;
231         struct {
232                 struct xkb_state *state;
233                 uint32_t mods_depressed;
234                 uint32_t mods_latched;
235                 uint32_t mods_locked;
236                 uint32_t group;
237                 enum weston_led leds;
238         } xkb_state;
239 };
240
241 struct weston_shader {
242         GLuint program;
243         GLuint vertex_shader, fragment_shader;
244         GLint proj_uniform;
245         GLint tex_uniform;
246         GLint alpha_uniform;
247         GLint color_uniform;
248         GLint texwidth_uniform;
249         GLint opaque_uniform;
250 };
251
252 enum {
253         WESTON_COMPOSITOR_ACTIVE,
254         WESTON_COMPOSITOR_IDLE,         /* shell->unlock called on activity */
255         WESTON_COMPOSITOR_SLEEPING      /* no rendering, no frame events */
256 };
257
258 struct weston_layer {
259         struct wl_list surface_list;
260         struct wl_list link;
261 };
262
263 struct weston_compositor {
264         struct wl_shm *shm;
265         struct wl_signal destroy_signal;
266
267         EGLDisplay egl_display;
268         EGLContext egl_context;
269         EGLConfig egl_config;
270         GLuint fbo;
271         struct weston_shader texture_shader;
272         struct weston_shader solid_shader;
273         struct weston_shader *current_shader;
274         struct wl_display *wl_display;
275         struct weston_shell_interface shell_interface;
276
277         struct wl_signal activate_signal;
278         struct wl_signal lock_signal;
279         struct wl_signal unlock_signal;
280
281         struct wl_event_loop *input_loop;
282         struct wl_event_source *input_loop_source;
283
284         /* There can be more than one, but not right now... */
285         struct weston_seat *seat;
286
287         struct weston_layer fade_layer;
288         struct weston_layer cursor_layer;
289
290         struct wl_list output_list;
291         struct wl_list seat_list;
292         struct wl_list layer_list;
293         struct wl_list surface_list;
294         struct wl_list key_binding_list;
295         struct wl_list button_binding_list;
296         struct wl_list axis_binding_list;
297         struct {
298                 struct weston_spring spring;
299                 struct weston_animation animation;
300                 struct weston_surface *surface;
301         } fade;
302
303         uint32_t state;
304         struct wl_event_source *idle_source;
305         uint32_t idle_inhibit;
306         int option_idle_time;           /* default timeout, s */
307         int idle_time;                  /* effective timeout, s */
308
309         /* Repaint state. */
310         struct wl_array vertices, indices;
311         pixman_region32_t damage;
312
313         uint32_t focus;
314
315         PFNGLEGLIMAGETARGETRENDERBUFFERSTORAGEOESPROC
316                 image_target_renderbuffer_storage;
317         PFNGLEGLIMAGETARGETTEXTURE2DOESPROC image_target_texture_2d;
318         PFNEGLCREATEIMAGEKHRPROC create_image;
319         PFNEGLDESTROYIMAGEKHRPROC destroy_image;
320
321         int has_unpack_subimage;
322         GLenum read_format;
323
324         PFNEGLBINDWAYLANDDISPLAYWL bind_display;
325         PFNEGLUNBINDWAYLANDDISPLAYWL unbind_display;
326         int has_bind_display;
327
328         void (*destroy)(struct weston_compositor *ec);
329         int (*authenticate)(struct weston_compositor *c, uint32_t id);
330
331         void (*ping_handler)(struct weston_surface *surface, uint32_t serial);
332
333         int launcher_sock;
334
335         uint32_t output_id_pool;
336
337         struct xkb_rule_names xkb_names;
338         struct xkb_context *xkb_context;
339         struct weston_xkb_info xkb_info;
340 };
341
342 enum weston_output_flags {
343         WL_OUTPUT_FLIPPED = 0x01
344 };
345
346 struct weston_region {
347         struct wl_resource resource;
348         pixman_region32_t region;
349 };
350
351 /* Using weston_surface transformations
352  *
353  * To add a transformation to a surface, create a struct weston_transform, and
354  * add it to the list surface->geometry.transformation_list. Whenever you
355  * change the list, anything under surface->geometry, or anything in the
356  * weston_transforms linked into the list, you must set
357  * surface->geometry.dirty = 1.
358  *
359  * The order in the list defines the order of transformations. Let the list
360  * contain the transformation matrices M1, ..., Mn as head to tail. The
361  * transformation is applied to surface-local coordinate vector p as
362  *    P = Mn * ... * M2 * M1 * p
363  * to produce the global coordinate vector P. The total transform
364  *    Mn * ... * M2 * M1
365  * is cached in surface->transform.matrix, and the inverse of it in
366  * surface->transform.inverse.
367  *
368  * The list always contains surface->transform.position transformation, which
369  * is the translation by surface->geometry.x and y.
370  *
371  * If you want to apply a transformation in local coordinates, add your
372  * weston_transform to the head of the list. If you want to apply a
373  * transformation in global coordinates, add it to the tail of the list.
374  */
375
376 enum {
377         WESTON_PLANE_PRIMARY
378 };
379
380 struct weston_surface {
381         struct wl_surface surface;
382         struct weston_compositor *compositor;
383         GLuint texture;
384         pixman_region32_t clip;
385         pixman_region32_t damage;
386         pixman_region32_t opaque;
387         pixman_region32_t input;
388         int32_t pitch;
389         struct wl_list link;
390         struct wl_list layer_link;
391         struct weston_shader *shader;
392         GLfloat color[4];
393         GLfloat opaque_rect[4];
394         GLfloat alpha;
395         int blend;
396         int plane;
397
398         /* Surface geometry state, mutable.
399          * If you change anything, set dirty = 1.
400          * That includes the transformations referenced from the list.
401          */
402         struct {
403                 GLfloat x, y; /* surface translation on display */
404                 int32_t width, height;
405
406                 /* struct weston_transform */
407                 struct wl_list transformation_list;
408
409                 int dirty;
410         } geometry;
411
412         /* State derived from geometry state, read-only.
413          * This is updated by weston_surface_update_transform().
414          */
415         struct {
416                 pixman_region32_t boundingbox;
417                 pixman_region32_t opaque;
418
419                 /* matrix and inverse are used only if enabled = 1.
420                  * If enabled = 0, use x, y, width, height directly.
421                  */
422                 int enabled;
423                 struct weston_matrix matrix;
424                 struct weston_matrix inverse;
425
426                 struct weston_transform position; /* matrix from x, y */
427         } transform;
428
429         /*
430          * Which output to vsync this surface to.
431          * Used to determine, whether to send or queue frame events.
432          * Must be NULL, if 'link' is not in weston_compositor::surface_list.
433          */
434         struct weston_output *output;
435
436         /*
437          * A more complete representation of all outputs this surface is
438          * displayed on.
439          */
440         uint32_t output_mask;
441
442         struct wl_list frame_callback_list;
443
444         EGLImageKHR image;
445
446         struct wl_buffer *buffer;
447         struct wl_listener buffer_destroy_listener;
448
449         /*
450          * If non-NULL, this function will be called on surface::attach after
451          * a new buffer has been set up for this surface. The integer params
452          * are the sx and sy paramerters supplied to surface::attach .
453          */
454         void (*configure)(struct weston_surface *es, int32_t sx, int32_t sy);
455         void *private;
456 };
457
458 void
459 weston_surface_update_transform(struct weston_surface *surface);
460
461 void
462 weston_surface_to_global_fixed(struct weston_surface *surface,
463                                wl_fixed_t sx, wl_fixed_t sy,
464                                wl_fixed_t *x, wl_fixed_t *y);
465 void
466 weston_surface_to_global_float(struct weston_surface *surface,
467                                GLfloat sx, GLfloat sy, GLfloat *x, GLfloat *y);
468
469 void
470 weston_surface_from_global(struct weston_surface *surface,
471                            int32_t x, int32_t y, int32_t *sx, int32_t *sy);
472 void
473 weston_surface_from_global_fixed(struct weston_surface *surface,
474                                  wl_fixed_t x, wl_fixed_t y,
475                                  wl_fixed_t *sx, wl_fixed_t *sy);
476
477 void
478 weston_spring_init(struct weston_spring *spring,
479                    double k, double current, double target);
480 void
481 weston_spring_update(struct weston_spring *spring, uint32_t msec);
482 int
483 weston_spring_done(struct weston_spring *spring);
484
485 void
486 weston_surface_activate(struct weston_surface *surface,
487                         struct weston_seat *seat);
488 void
489 weston_surface_draw(struct weston_surface *es,
490                     struct weston_output *output, pixman_region32_t *damage);
491
492 void
493 notify_motion(struct wl_seat *seat, uint32_t time,
494               wl_fixed_t x, wl_fixed_t y);
495 void
496 notify_button(struct wl_seat *seat, uint32_t time, int32_t button,
497               enum wl_pointer_button_state state);
498 void
499 notify_axis(struct wl_seat *seat, uint32_t time, uint32_t axis,
500             wl_fixed_t value);
501 void
502 notify_key(struct wl_seat *seat, uint32_t time, uint32_t key,
503            enum wl_keyboard_key_state state);
504
505 void
506 notify_pointer_focus(struct wl_seat *seat, struct weston_output *output,
507                      wl_fixed_t x, wl_fixed_t y);
508
509 void
510 notify_keyboard_focus(struct wl_seat *seat, struct wl_array *keys);
511
512 void
513 notify_touch(struct wl_seat *seat, uint32_t time, int touch_id,
514              wl_fixed_t x, wl_fixed_t y, int touch_type);
515
516 void
517 weston_layer_init(struct weston_layer *layer, struct wl_list *below);
518
519 void
520 weston_output_finish_frame(struct weston_output *output, int msecs);
521 void
522 weston_output_damage(struct weston_output *output);
523 void
524 weston_compositor_schedule_repaint(struct weston_compositor *compositor);
525 void
526 weston_compositor_fade(struct weston_compositor *compositor, float tint);
527 void
528 weston_compositor_damage_all(struct weston_compositor *compositor);
529 void
530 weston_compositor_unlock(struct weston_compositor *compositor);
531 void
532 weston_compositor_wake(struct weston_compositor *compositor);
533 void
534 weston_compositor_activity(struct weston_compositor *compositor);
535 void
536 weston_compositor_update_drag_surfaces(struct weston_compositor *compositor);
537
538
539 struct weston_binding;
540 typedef void (*weston_key_binding_handler_t)(struct wl_seat *seat,
541                                              uint32_t time, uint32_t key,
542                                              void *data);
543 struct weston_binding *
544 weston_compositor_add_key_binding(struct weston_compositor *compositor,
545                                   uint32_t key,
546                                   enum weston_keyboard_modifier modifier,
547                                   weston_key_binding_handler_t binding,
548                                   void *data);
549
550 typedef void (*weston_button_binding_handler_t)(struct wl_seat *seat,
551                                                 uint32_t time, uint32_t button,
552                                                 void *data);
553 struct weston_binding *
554 weston_compositor_add_button_binding(struct weston_compositor *compositor,
555                                      uint32_t button,
556                                      enum weston_keyboard_modifier modifier,
557                                      weston_button_binding_handler_t binding,
558                                      void *data);
559
560 typedef void (*weston_axis_binding_handler_t)(struct wl_seat *seat,
561                                               uint32_t time, uint32_t axis,
562                                               wl_fixed_t value, void *data);
563 struct weston_binding *
564 weston_compositor_add_axis_binding(struct weston_compositor *compositor,
565                                    uint32_t axis,
566                                    enum weston_keyboard_modifier modifier,
567                                    weston_axis_binding_handler_t binding,
568                                    void *data);
569 void
570 weston_binding_destroy(struct weston_binding *binding);
571
572 void
573 weston_binding_list_destroy_all(struct wl_list *list);
574
575 void
576 weston_compositor_run_key_binding(struct weston_compositor *compositor,
577                                   struct weston_seat *seat, uint32_t time,
578                                   uint32_t key,
579                                   enum wl_keyboard_key_state state);
580 void
581 weston_compositor_run_button_binding(struct weston_compositor *compositor,
582                                      struct weston_seat *seat, uint32_t time,
583                                      uint32_t button,
584                                      enum wl_pointer_button_state value);
585 void
586 weston_compositor_run_axis_binding(struct weston_compositor *compositor,
587                                    struct weston_seat *seat, uint32_t time,
588                                    uint32_t axis, int32_t value);
589
590 int
591 weston_environment_get_fd(const char *env);
592
593 struct wl_list *
594 weston_compositor_top(struct weston_compositor *compositor);
595
596 struct weston_surface *
597 weston_surface_create(struct weston_compositor *compositor);
598
599 void
600 weston_surface_configure(struct weston_surface *surface,
601                          GLfloat x, GLfloat y, int width, int height);
602
603 void
604 weston_surface_restack(struct weston_surface *surface, struct wl_list *below);
605
606 void
607 weston_surface_set_position(struct weston_surface *surface,
608                             GLfloat x, GLfloat y);
609
610 int
611 weston_surface_is_mapped(struct weston_surface *surface);
612
613 void
614 weston_surface_assign_output(struct weston_surface *surface);
615
616 void
617 weston_surface_damage(struct weston_surface *surface);
618
619 void
620 weston_surface_damage_below(struct weston_surface *surface);
621
622 void
623 weston_buffer_post_release(struct wl_buffer *buffer);
624
625 uint32_t
626 weston_compositor_get_time(void);
627
628 int
629 weston_compositor_init(struct weston_compositor *ec, struct wl_display *display,
630                        int argc, char *argv[], const char *config_file);
631 void
632 weston_compositor_shutdown(struct weston_compositor *ec);
633 void
634 weston_text_cursor_position_notify(struct weston_surface *surface,
635                                                 wl_fixed_t x, wl_fixed_t y);
636 void
637 weston_output_init_zoom(struct weston_output *output);
638 void
639 weston_output_update_zoom(struct weston_output *output, uint32_t type);
640 void
641 weston_output_update_matrix(struct weston_output *output);
642 void
643 weston_output_move(struct weston_output *output, int x, int y);
644 void
645 weston_output_init(struct weston_output *output, struct weston_compositor *c,
646                    int x, int y, int width, int height, uint32_t flags);
647 void
648 weston_output_destroy(struct weston_output *output);
649
650 void
651 weston_seat_init(struct weston_seat *seat, struct weston_compositor *ec);
652 void
653 weston_seat_init_pointer(struct weston_seat *seat);
654 void
655 weston_seat_init_keyboard(struct weston_seat *seat, struct xkb_keymap *keymap);
656 void
657 weston_seat_init_touch(struct weston_seat *seat);
658
659 void
660 weston_seat_release(struct weston_seat *seat);
661
662 enum {
663         TTY_ENTER_VT,
664         TTY_LEAVE_VT
665 };
666
667 typedef void (*tty_vt_func_t)(struct weston_compositor *compositor, int event);
668
669 struct tty *
670 tty_create(struct weston_compositor *compositor,
671            tty_vt_func_t vt_func, int tty_nr);
672
673 void
674 tty_destroy(struct tty *tty);
675
676 int
677 tty_activate_vt(struct tty *tty, int vt);
678
679 void
680 screenshooter_create(struct weston_compositor *ec);
681
682 struct clipboard *
683 clipboard_create(struct weston_seat *seat);
684
685 void
686 text_cursor_position_notifier_create(struct weston_compositor *ec);
687
688 struct weston_process;
689 typedef void (*weston_process_cleanup_func_t)(struct weston_process *process,
690                                             int status);
691
692 struct weston_process {
693         pid_t pid;
694         weston_process_cleanup_func_t cleanup;
695         struct wl_list link;
696 };
697
698 struct wl_client *
699 weston_client_launch(struct weston_compositor *compositor,
700                      struct weston_process *proc,
701                      const char *path,
702                      weston_process_cleanup_func_t cleanup);
703
704 void
705 weston_watch_process(struct weston_process *process);
706
707 int
708 weston_xserver_init(struct weston_compositor *compositor);
709
710 struct weston_zoom;
711 typedef void (*weston_zoom_done_func_t)(struct weston_zoom *zoom, void *data);
712
713 struct weston_zoom *
714 weston_zoom_run(struct weston_surface *surface, GLfloat start, GLfloat stop,
715                 weston_zoom_done_func_t done, void *data);
716
717 struct weston_fade;
718 typedef void (*weston_fade_done_func_t)(struct weston_fade *fade, void *data);
719
720 struct weston_fade *
721 weston_fade_run(struct weston_surface *surface,
722                 weston_fade_done_func_t done, void *data);
723
724
725 void
726 weston_surface_set_color(struct weston_surface *surface,
727                          GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha);
728
729 void
730 weston_surface_destroy(struct weston_surface *surface);
731
732 struct weston_compositor *
733 backend_init(struct wl_display *display, int argc, char *argv[],
734              const char *config_file);
735
736 int
737 weston_output_switch_mode(struct weston_output *output, struct weston_mode *mode);
738
739 #endif