compositor: Buffer all frame callbacks in 'weston_surface'
[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_output_zoom {
119         int active;
120         uint32_t type;
121         float increment;
122         float level;
123         float max_level;
124         wl_fixed_t fx, fy;
125         float trans_x, trans_y;
126         struct weston_animation animation_z;
127         struct weston_spring spring_z;
128 };
129
130 /* bit compatible with drm definitions. */
131 enum dpms_enum {
132         WESTON_DPMS_ON,
133         WESTON_DPMS_STANDBY,
134         WESTON_DPMS_SUSPEND,
135         WESTON_DPMS_OFF
136 };
137
138 struct weston_read_pixels {
139         void *data;
140         int x, y, width, height;
141         void (*done)(struct weston_read_pixels *read_pixels,
142                      struct weston_output *output);
143         struct wl_list link;
144 };
145
146 struct weston_output {
147         uint32_t id;
148
149         struct wl_list link;
150         struct wl_list resource_list;
151         struct wl_global *global;
152         struct weston_compositor *compositor;
153         struct weston_matrix matrix;
154         struct wl_list animation_list;
155         int32_t x, y, mm_width, mm_height;
156         struct weston_border border;
157         pixman_region32_t region;
158         pixman_region32_t previous_damage;
159         uint32_t flags;
160         int repaint_needed;
161         int repaint_scheduled;
162         struct weston_output_zoom zoom;
163         int dirty;
164         struct wl_list read_pixels_list;
165         struct wl_signal frame_signal;
166
167         char *make, *model;
168         uint32_t subpixel;
169         
170         struct weston_mode *current;
171         struct weston_mode *origin;
172         struct wl_list mode_list;
173
174         void (*repaint)(struct weston_output *output,
175                         pixman_region32_t *damage);
176         void (*destroy)(struct weston_output *output);
177         void (*assign_planes)(struct weston_output *output);
178         int (*switch_mode)(struct weston_output *output, struct weston_mode *mode);
179
180         /* backlight values are on 0-255 range, where higher is brighter */
181         uint32_t backlight_current;
182         void (*set_backlight)(struct weston_output *output, uint32_t value);
183         void (*set_dpms)(struct weston_output *output, enum dpms_enum level);
184 };
185
186 struct weston_xkb_info {
187         struct xkb_keymap *keymap;
188         int keymap_fd;
189         size_t keymap_size;
190         char *keymap_area;
191         xkb_mod_index_t ctrl_mod;
192         xkb_mod_index_t alt_mod;
193         xkb_mod_index_t super_mod;
194         xkb_led_index_t num_led;
195         xkb_led_index_t caps_led;
196         xkb_led_index_t scroll_led;
197 };
198
199 struct weston_seat {
200         struct wl_seat seat;
201         struct wl_pointer pointer;
202         int has_pointer;
203         struct wl_keyboard keyboard;
204         int has_keyboard;
205         struct wl_touch touch;
206         int has_touch;
207
208         struct weston_compositor *compositor;
209         struct weston_surface *sprite;
210         struct weston_surface *drag_surface;
211         struct wl_listener drag_surface_destroy_listener;
212         int32_t hotspot_x, hotspot_y;
213         struct wl_list link;
214         enum weston_keyboard_modifier modifier_state;
215         int hw_cursor;
216         struct wl_surface *saved_kbd_focus;
217         struct wl_listener saved_kbd_focus_listener;
218
219         uint32_t num_tp;
220         struct wl_surface *touch_focus;
221         struct wl_listener touch_focus_listener;
222         struct wl_resource *touch_focus_resource;
223         struct wl_listener touch_focus_resource_listener;
224
225         struct wl_listener new_drag_icon_listener;
226
227         void (*led_update)(struct weston_seat *ws, enum weston_led leds);
228
229         struct weston_xkb_info xkb_info;
230         struct {
231                 struct xkb_state *state;
232                 uint32_t mods_depressed;
233                 uint32_t mods_latched;
234                 uint32_t mods_locked;
235                 uint32_t group;
236                 enum weston_led leds;
237         } xkb_state;
238 };
239
240 struct weston_shader {
241         GLuint program;
242         GLuint vertex_shader, fragment_shader;
243         GLint proj_uniform;
244         GLint tex_uniform;
245         GLint alpha_uniform;
246         GLint color_uniform;
247         GLint texwidth_uniform;
248         GLint opaque_uniform;
249 };
250
251 enum {
252         WESTON_COMPOSITOR_ACTIVE,
253         WESTON_COMPOSITOR_IDLE,         /* shell->unlock called on activity */
254         WESTON_COMPOSITOR_SLEEPING      /* no rendering, no frame events */
255 };
256
257 struct weston_layer {
258         struct wl_list surface_list;
259         struct wl_list link;
260 };
261
262 struct weston_compositor {
263         struct wl_shm *shm;
264         struct wl_signal destroy_signal;
265
266         EGLDisplay display;
267         EGLContext context;
268         EGLConfig config;
269         GLuint fbo;
270         struct weston_shader texture_shader;
271         struct weston_shader solid_shader;
272         struct weston_shader *current_shader;
273         struct wl_display *wl_display;
274         struct weston_shell_interface shell_interface;
275
276         struct wl_signal activate_signal;
277         struct wl_signal lock_signal;
278         struct wl_signal unlock_signal;
279
280         struct wl_event_loop *input_loop;
281         struct wl_event_source *input_loop_source;
282
283         /* There can be more than one, but not right now... */
284         struct weston_seat *seat;
285
286         struct weston_layer fade_layer;
287         struct weston_layer cursor_layer;
288
289         struct wl_list output_list;
290         struct wl_list seat_list;
291         struct wl_list layer_list;
292         struct wl_list surface_list;
293         struct wl_list key_binding_list;
294         struct wl_list button_binding_list;
295         struct wl_list axis_binding_list;
296         struct {
297                 struct weston_spring spring;
298                 struct weston_animation animation;
299                 struct weston_surface *surface;
300         } fade;
301
302         uint32_t state;
303         struct wl_event_source *idle_source;
304         uint32_t idle_inhibit;
305         int option_idle_time;           /* default timeout, s */
306         int idle_time;                  /* effective timeout, s */
307
308         /* Repaint state. */
309         struct wl_array vertices, indices;
310         pixman_region32_t damage;
311
312         uint32_t focus;
313
314         PFNGLEGLIMAGETARGETRENDERBUFFERSTORAGEOESPROC
315                 image_target_renderbuffer_storage;
316         PFNGLEGLIMAGETARGETTEXTURE2DOESPROC image_target_texture_2d;
317         PFNEGLCREATEIMAGEKHRPROC create_image;
318         PFNEGLDESTROYIMAGEKHRPROC destroy_image;
319
320         int has_unpack_subimage;
321         GLenum read_format;
322
323         PFNEGLBINDWAYLANDDISPLAYWL bind_display;
324         PFNEGLUNBINDWAYLANDDISPLAYWL unbind_display;
325         int has_bind_display;
326
327         void (*destroy)(struct weston_compositor *ec);
328         int (*authenticate)(struct weston_compositor *c, uint32_t id);
329
330         void (*ping_handler)(struct weston_surface *surface, uint32_t serial);
331
332         int launcher_sock;
333
334         uint32_t output_id_pool;
335
336         struct xkb_rule_names xkb_names;
337         struct xkb_context *xkb_context;
338         struct weston_xkb_info xkb_info;
339 };
340
341 enum weston_output_flags {
342         WL_OUTPUT_FLIPPED = 0x01
343 };
344
345 struct weston_region {
346         struct wl_resource resource;
347         pixman_region32_t region;
348 };
349
350 /* Using weston_surface transformations
351  *
352  * To add a transformation to a surface, create a struct weston_transform, and
353  * add it to the list surface->geometry.transformation_list. Whenever you
354  * change the list, anything under surface->geometry, or anything in the
355  * weston_transforms linked into the list, you must set
356  * surface->geometry.dirty = 1.
357  *
358  * The order in the list defines the order of transformations. Let the list
359  * contain the transformation matrices M1, ..., Mn as head to tail. The
360  * transformation is applied to surface-local coordinate vector p as
361  *    P = Mn * ... * M2 * M1 * p
362  * to produce the global coordinate vector P. The total transform
363  *    Mn * ... * M2 * M1
364  * is cached in surface->transform.matrix, and the inverse of it in
365  * surface->transform.inverse.
366  *
367  * The list always contains surface->transform.position transformation, which
368  * is the translation by surface->geometry.x and y.
369  *
370  * If you want to apply a transformation in local coordinates, add your
371  * weston_transform to the head of the list. If you want to apply a
372  * transformation in global coordinates, add it to the tail of the list.
373  */
374
375 struct weston_surface {
376         struct wl_surface surface;
377         struct weston_compositor *compositor;
378         GLuint texture;
379         pixman_region32_t clip;
380         pixman_region32_t damage;
381         pixman_region32_t opaque;
382         pixman_region32_t input;
383         int32_t pitch;
384         struct wl_list link;
385         struct wl_list layer_link;
386         struct weston_shader *shader;
387         GLfloat color[4];
388         GLfloat opaque_rect[4];
389         GLfloat alpha;
390         int blend;
391
392         /* Surface geometry state, mutable.
393          * If you change anything, set dirty = 1.
394          * That includes the transformations referenced from the list.
395          */
396         struct {
397                 GLfloat x, y; /* surface translation on display */
398                 int32_t width, height;
399
400                 /* struct weston_transform */
401                 struct wl_list transformation_list;
402
403                 int dirty;
404         } geometry;
405
406         /* State derived from geometry state, read-only.
407          * This is updated by weston_surface_update_transform().
408          */
409         struct {
410                 pixman_region32_t boundingbox;
411                 pixman_region32_t opaque;
412
413                 /* matrix and inverse are used only if enabled = 1.
414                  * If enabled = 0, use x, y, width, height directly.
415                  */
416                 int enabled;
417                 struct weston_matrix matrix;
418                 struct weston_matrix inverse;
419
420                 struct weston_transform position; /* matrix from x, y */
421         } transform;
422
423         /*
424          * Which output to vsync this surface to.
425          * Used to determine, whether to send or queue frame events.
426          * Must be NULL, if 'link' is not in weston_compositor::surface_list.
427          */
428         struct weston_output *output;
429
430         /*
431          * A more complete representation of all outputs this surface is
432          * displayed on.
433          */
434         uint32_t output_mask;
435
436         struct wl_list frame_callback_list;
437
438         EGLImageKHR image;
439
440         struct wl_buffer *buffer;
441         struct wl_listener buffer_destroy_listener;
442
443         /*
444          * If non-NULL, this function will be called on surface::attach after
445          * a new buffer has been set up for this surface. The integer params
446          * are the sx and sy paramerters supplied to surface::attach .
447          */
448         void (*configure)(struct weston_surface *es, int32_t sx, int32_t sy);
449         void *private;
450 };
451
452 void
453 weston_surface_update_transform(struct weston_surface *surface);
454
455 void
456 weston_surface_to_global_fixed(struct weston_surface *surface,
457                                wl_fixed_t sx, wl_fixed_t sy,
458                                wl_fixed_t *x, wl_fixed_t *y);
459 void
460 weston_surface_to_global_float(struct weston_surface *surface,
461                                GLfloat sx, GLfloat sy, GLfloat *x, GLfloat *y);
462
463 void
464 weston_surface_from_global(struct weston_surface *surface,
465                            int32_t x, int32_t y, int32_t *sx, int32_t *sy);
466 void
467 weston_surface_from_global_fixed(struct weston_surface *surface,
468                                  wl_fixed_t x, wl_fixed_t y,
469                                  wl_fixed_t *sx, wl_fixed_t *sy);
470
471 void
472 weston_spring_init(struct weston_spring *spring,
473                    double k, double current, double target);
474 void
475 weston_spring_update(struct weston_spring *spring, uint32_t msec);
476 int
477 weston_spring_done(struct weston_spring *spring);
478
479 void
480 weston_surface_activate(struct weston_surface *surface,
481                         struct weston_seat *seat);
482 void
483 weston_surface_draw(struct weston_surface *es,
484                     struct weston_output *output, pixman_region32_t *damage);
485
486 void
487 notify_motion(struct wl_seat *seat, uint32_t time,
488               wl_fixed_t x, wl_fixed_t y);
489 void
490 notify_button(struct wl_seat *seat, uint32_t time, int32_t button,
491               enum wl_pointer_button_state state);
492 void
493 notify_axis(struct wl_seat *seat, uint32_t time, uint32_t axis,
494             wl_fixed_t value);
495 void
496 notify_key(struct wl_seat *seat, uint32_t time, uint32_t key,
497            enum wl_keyboard_key_state state);
498
499 void
500 notify_pointer_focus(struct wl_seat *seat, struct weston_output *output,
501                      wl_fixed_t x, wl_fixed_t y);
502
503 void
504 notify_keyboard_focus(struct wl_seat *seat, struct wl_array *keys);
505
506 void
507 notify_touch(struct wl_seat *seat, uint32_t time, int touch_id,
508              wl_fixed_t x, wl_fixed_t y, int touch_type);
509
510 void
511 weston_layer_init(struct weston_layer *layer, struct wl_list *below);
512
513 void
514 weston_output_finish_frame(struct weston_output *output, int msecs);
515 void
516 weston_output_damage(struct weston_output *output);
517 void
518 weston_output_do_read_pixels(struct weston_output *output);
519 void
520 weston_compositor_repick(struct weston_compositor *compositor);
521 void
522 weston_compositor_schedule_repaint(struct weston_compositor *compositor);
523 void
524 weston_compositor_fade(struct weston_compositor *compositor, float tint);
525 void
526 weston_compositor_damage_all(struct weston_compositor *compositor);
527 void
528 weston_compositor_unlock(struct weston_compositor *compositor);
529 void
530 weston_compositor_wake(struct weston_compositor *compositor);
531 void
532 weston_compositor_activity(struct weston_compositor *compositor);
533 void
534 weston_compositor_update_drag_surfaces(struct weston_compositor *compositor);
535
536
537 struct weston_binding;
538 typedef void (*weston_key_binding_handler_t)(struct wl_seat *seat,
539                                              uint32_t time, uint32_t key,
540                                              void *data);
541 struct weston_binding *
542 weston_compositor_add_key_binding(struct weston_compositor *compositor,
543                                   uint32_t key,
544                                   enum weston_keyboard_modifier modifier,
545                                   weston_key_binding_handler_t binding,
546                                   void *data);
547
548 typedef void (*weston_button_binding_handler_t)(struct wl_seat *seat,
549                                                 uint32_t time, uint32_t button,
550                                                 void *data);
551 struct weston_binding *
552 weston_compositor_add_button_binding(struct weston_compositor *compositor,
553                                      uint32_t button,
554                                      enum weston_keyboard_modifier modifier,
555                                      weston_button_binding_handler_t binding,
556                                      void *data);
557
558 typedef void (*weston_axis_binding_handler_t)(struct wl_seat *seat,
559                                               uint32_t time, uint32_t axis,
560                                               wl_fixed_t value, void *data);
561 struct weston_binding *
562 weston_compositor_add_axis_binding(struct weston_compositor *compositor,
563                                    uint32_t axis,
564                                    enum weston_keyboard_modifier modifier,
565                                    weston_axis_binding_handler_t binding,
566                                    void *data);
567 void
568 weston_binding_destroy(struct weston_binding *binding);
569
570 void
571 weston_binding_list_destroy_all(struct wl_list *list);
572
573 void
574 weston_compositor_run_key_binding(struct weston_compositor *compositor,
575                                   struct weston_seat *seat, uint32_t time,
576                                   uint32_t key,
577                                   enum wl_keyboard_key_state state);
578 void
579 weston_compositor_run_button_binding(struct weston_compositor *compositor,
580                                      struct weston_seat *seat, uint32_t time,
581                                      uint32_t button,
582                                      enum wl_pointer_button_state value);
583 void
584 weston_compositor_run_axis_binding(struct weston_compositor *compositor,
585                                    struct weston_seat *seat, uint32_t time,
586                                    uint32_t axis, int32_t value);
587
588 int
589 weston_environment_get_fd(const char *env);
590
591 struct wl_list *
592 weston_compositor_top(struct weston_compositor *compositor);
593
594 struct weston_surface *
595 weston_surface_create(struct weston_compositor *compositor);
596
597 void
598 weston_surface_configure(struct weston_surface *surface,
599                          GLfloat x, GLfloat y, int width, int height);
600
601 void
602 weston_surface_restack(struct weston_surface *surface, struct wl_list *below);
603
604 void
605 weston_surface_set_position(struct weston_surface *surface,
606                             GLfloat x, GLfloat y);
607
608 int
609 weston_surface_is_mapped(struct weston_surface *surface);
610
611 void
612 weston_surface_assign_output(struct weston_surface *surface);
613
614 void
615 weston_surface_damage(struct weston_surface *surface);
616
617 void
618 weston_surface_damage_below(struct weston_surface *surface);
619
620 void
621 weston_buffer_post_release(struct wl_buffer *buffer);
622
623 uint32_t
624 weston_compositor_get_time(void);
625
626 int
627 weston_compositor_init(struct weston_compositor *ec, struct wl_display *display,
628                        int argc, char *argv[], const char *config_file);
629 void
630 weston_compositor_shutdown(struct weston_compositor *ec);
631 void
632 weston_text_cursor_position_notify(struct weston_surface *surface,
633                                                 wl_fixed_t x, wl_fixed_t y);
634 void
635 weston_output_update_zoom(struct weston_output *output,
636                                                 wl_fixed_t x, wl_fixed_t y,
637                                                 uint32_t type);
638 void
639 weston_output_update_matrix(struct weston_output *output);
640 void
641 weston_output_move(struct weston_output *output, int x, int y);
642 void
643 weston_output_init(struct weston_output *output, struct weston_compositor *c,
644                    int x, int y, int width, int height, uint32_t flags);
645 void
646 weston_output_destroy(struct weston_output *output);
647
648 void
649 weston_seat_init(struct weston_seat *seat, struct weston_compositor *ec);
650 void
651 weston_seat_init_pointer(struct weston_seat *seat);
652 void
653 weston_seat_init_keyboard(struct weston_seat *seat, struct xkb_keymap *keymap);
654 void
655 weston_seat_init_touch(struct weston_seat *seat);
656
657 void
658 weston_seat_release(struct weston_seat *seat);
659
660 enum {
661         TTY_ENTER_VT,
662         TTY_LEAVE_VT
663 };
664
665 typedef void (*tty_vt_func_t)(struct weston_compositor *compositor, int event);
666
667 struct tty *
668 tty_create(struct weston_compositor *compositor,
669            tty_vt_func_t vt_func, int tty_nr);
670
671 void
672 tty_destroy(struct tty *tty);
673
674 int
675 tty_activate_vt(struct tty *tty, int vt);
676
677 void
678 screenshooter_create(struct weston_compositor *ec);
679
680 struct clipboard *
681 clipboard_create(struct weston_seat *seat);
682
683 void
684 text_cursor_position_notifier_create(struct weston_compositor *ec);
685
686 struct weston_process;
687 typedef void (*weston_process_cleanup_func_t)(struct weston_process *process,
688                                             int status);
689
690 struct weston_process {
691         pid_t pid;
692         weston_process_cleanup_func_t cleanup;
693         struct wl_list link;
694 };
695
696 struct wl_client *
697 weston_client_launch(struct weston_compositor *compositor,
698                      struct weston_process *proc,
699                      const char *path,
700                      weston_process_cleanup_func_t cleanup);
701
702 void
703 weston_watch_process(struct weston_process *process);
704
705 int
706 weston_xserver_init(struct weston_compositor *compositor);
707
708 struct weston_zoom;
709 typedef void (*weston_zoom_done_func_t)(struct weston_zoom *zoom, void *data);
710
711 struct weston_zoom *
712 weston_zoom_run(struct weston_surface *surface, GLfloat start, GLfloat stop,
713                 weston_zoom_done_func_t done, void *data);
714
715 struct weston_fade;
716 typedef void (*weston_fade_done_func_t)(struct weston_fade *fade, void *data);
717
718 struct weston_fade *
719 weston_fade_run(struct weston_surface *surface,
720                 weston_fade_done_func_t done, void *data);
721
722
723 void
724 weston_surface_set_color(struct weston_surface *surface,
725                          GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha);
726
727 void
728 weston_surface_destroy(struct weston_surface *surface);
729
730 struct weston_compositor *
731 backend_init(struct wl_display *display, int argc, char *argv[],
732              const char *config_file);
733
734 int
735 weston_output_switch_mode(struct weston_output *output, struct weston_mode *mode);
736
737 #endif