diff options
author | Kristian Høgsberg <krh@bitplanet.net> | 2013-02-13 17:45:01 -0500 |
---|---|---|
committer | Kristian Høgsberg <krh@bitplanet.net> | 2013-02-13 21:47:14 -0500 |
commit | 90657356ac83b0c735e7dbbbd750023da69a0da7 (patch) | |
tree | a2dca25d31c3460ca34b10f36e1ba28d168d953a |
Standalone plugin initial commit
-rw-r--r-- | Makefile.am | 36 | ||||
-rw-r--r-- | configure.ac | 29 | ||||
-rw-r--r-- | overlay-client.c | 100 | ||||
-rw-r--r-- | overlay-plugin.c | 279 | ||||
-rw-r--r-- | overlay.xml | 14 | ||||
-rw-r--r-- | weston/compositor.h | 846 | ||||
-rw-r--r-- | weston/config-parser.h | 73 | ||||
-rw-r--r-- | weston/matrix.h | 74 |
8 files changed, 1451 insertions, 0 deletions
diff --git a/Makefile.am b/Makefile.am new file mode 100644 index 0000000..e3b11ba --- /dev/null +++ b/Makefile.am @@ -0,0 +1,36 @@ +libexec_PROGRAMS = weston-overlay + +weston_overlay_CPPFLAGS = $(CLIENT_CFLAGS) +weston_overlay_LDADD = $(CLIENT_LIBS) +weston_overlay_SOURCES = \ + overlay-client.c \ + overlay-client-protocol.h \ + overlay-protocol.c + +moduledir = @libdir@/weston +module_LTLIBRARIES = \ + overlay.la + +overlay_la_LDFLAGS = -module -avoid-version +overlay_la_CPPFLAGS = $(PLUGIN_CFLAGS) +overlay_la_SOURCES = \ + overlay-plugin.c \ + overlay-protocol.c \ + overlay-server-protocol.h + +EXTRA_DIST = \ + wayland-test.xml + +BUILT_SOURCES = \ + overlay-server-protocol.h \ + overlay-client-protocol.h \ + overlay-protocol.c + +%-protocol.c : %.xml + $(AM_V_GEN)$(WAYLAND_SCANNER) code < $< > $@ + +%-server-protocol.h : %.xml + $(AM_V_GEN)$(WAYLAND_SCANNER) server-header < $< > $@ + +%-client-protocol.h : %.xml + $(AM_V_GEN)$(WAYLAND_SCANNER) client-header < $< > $@ diff --git a/configure.ac b/configure.ac new file mode 100644 index 0000000..b6b746a --- /dev/null +++ b/configure.ac @@ -0,0 +1,29 @@ +AC_PREREQ([2.64]) +AC_INIT([overlay], + [0.1], + [https://bugs.freedesktop.org], + [overlay], + [http://wayland.freedesktop.org/]) + +AM_INIT_AUTOMAKE([1.11 foreign no-dist-gzip dist-xz]) + +AM_SILENT_RULES([yes]) + +# Check for programs +AC_PROG_CC + +LT_PREREQ([2.2]) +LT_INIT([disable-static]) + +PKG_PROG_PKG_CONFIG() + +PKG_CHECK_MODULES([CLIENT], [wayland-client >= 1.0.2]) +PKG_CHECK_MODULES([PLUGIN], [pixman-1 xkbcommon]) + +WAYLAND_PREFIX=`$PKG_CONFIG --variable=prefix wayland-client` +AC_PATH_PROG([WAYLAND_SCANNER], [wayland-scanner],, + [${WAYLAND_PREFIX}/bin$PATH_SEPARATOR$PATH]) + +AC_CONFIG_FILES([Makefile]) + +AC_OUTPUT diff --git a/overlay-client.c b/overlay-client.c new file mode 100644 index 0000000..ea34809 --- /dev/null +++ b/overlay-client.c @@ -0,0 +1,100 @@ +/* + * Copyright © 2013 Intel Corporation + * + * Permission to use, copy, modify, distribute, and sell this software and its + * documentation for any purpose is hereby granted without fee, provided that + * the above copyright notice appear in all copies and that both that copyright + * notice and this permission notice appear in supporting documentation, and + * that the name of the copyright holders not be used in advertising or + * publicity pertaining to distribution of the software without specific, + * written prior permission. The copyright holders make no representations + * about the suitability of this software for any purpose. It is provided "as + * is" without express or implied warranty. + * + * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, + * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO + * EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY SPECIAL, INDIRECT OR + * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE + * OF THIS SOFTWARE. + */ + +#include <string.h> +#include <stdlib.h> +#include <stdio.h> +#include <linux/input.h> + +#include "overlay-client-protocol.h" + +struct overlay_client { + struct wl_display *display; + struct wl_registry *registry; + struct wl_compositor *compositor; + struct wl_shell *shell; + struct overlay *overlay; +}; + +static void +overlay_activate(void *data, struct overlay *overlay) +{ + printf("got activate event, creating overlay\n"); +} + +static void +overlay_done(void *data, struct overlay *overlay) +{ + printf("got done event, destroying overlay\n"); +} + +static const struct overlay_listener listener = { + overlay_activate, + overlay_done +}; + +static void +registry_handle_global(void *data, struct wl_registry *registry, + uint32_t name, const char *interface, uint32_t version) +{ + struct overlay_client *client = data; + + if (strcmp(interface, "wl_compositor") == 0) { + client->compositor = + wl_registry_bind(registry, name, + &wl_compositor_interface, 1); + } else if (strcmp(interface, "wl_shell") == 0) { + client->shell = wl_registry_bind(registry, name, + &wl_shell_interface, 1); + } else if (strcmp(interface, "overlay") == 0) { + client->overlay = wl_registry_bind(registry, name, + &overlay_interface, 1); + overlay_add_listener(client->overlay, &listener, client); + } +} + +static void +registry_handle_global_remove(void *data, struct wl_registry *registry, + uint32_t name) +{ +} + +static const struct wl_registry_listener registry_listener = { + registry_handle_global, + registry_handle_global_remove +}; + +int main(int argc, char *argv[]) +{ + struct overlay_client *client; + + client = malloc(sizeof *client); + + client->display = wl_display_connect(NULL); + client->registry = wl_display_get_registry(client->display); + wl_registry_add_listener(client->registry, ®istry_listener, client); + + while (1) + wl_display_dispatch(client->display); + + return 0; +} diff --git a/overlay-plugin.c b/overlay-plugin.c new file mode 100644 index 0000000..35318a4 --- /dev/null +++ b/overlay-plugin.c @@ -0,0 +1,279 @@ +/* + * Copyright © 2013 Intel Corporation + * + * Permission to use, copy, modify, distribute, and sell this software and + * its documentation for any purpose is hereby granted without fee, provided + * that the above copyright notice appear in all copies and that both that + * copyright notice and this permission notice appear in supporting + * documentation, and that the name of the copyright holders not be used in + * advertising or publicity pertaining to distribution of the software + * without specific, written prior permission. The copyright holders make + * no representations about the suitability of this software for any + * purpose. It is provided "as is" without express or implied warranty. + * + * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS + * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND + * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY + * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER + * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF + * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN + * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include <stdlib.h> +#include <stdio.h> +#include <string.h> +#include <linux/input.h> +#include <fcntl.h> +#include <unistd.h> +#include <sys/uio.h> + +#include "weston/compositor.h" +#include "overlay-server-protocol.h" + +struct overlay { + struct weston_compositor *compositor; + struct wl_global *global; + struct wl_resource *resource; + struct wl_listener destroy_listener; + struct wl_listener surface_destroy_listener; + struct weston_surface *surface; + struct weston_binding *binding; + struct weston_layer layer; + struct wl_seat *seat; + struct wl_pointer_grab grab; + struct weston_output *output; +}; + +static void +handle_surface_destroy(struct wl_listener *listener, void *data) +{ + struct overlay *overlay = + container_of(listener, struct overlay, + surface_destroy_listener); + + overlay->surface = NULL; +} + +static void +overlay_close(struct overlay *overlay) +{ + overlay_send_done(overlay->resource); + wl_pointer_end_grab(overlay->grab.pointer); +} + +static void +overlay_grab_focus(struct wl_pointer_grab *grab, + struct wl_surface *surface, + wl_fixed_t x, wl_fixed_t y) +{ + struct wl_pointer *pointer = grab->pointer; + struct overlay *overlay = container_of(grab, struct overlay, grab); + + if (surface == &overlay->surface->surface) { + wl_pointer_set_focus(pointer, surface, x, y); + grab->focus = surface; + } else { + wl_pointer_set_focus(pointer, NULL, + wl_fixed_from_int(0), + wl_fixed_from_int(0)); + grab->focus = NULL; + } +} + +static void +overlay_grab_motion(struct wl_pointer_grab *grab, + uint32_t time, wl_fixed_t sx, wl_fixed_t sy) +{ + struct wl_resource *resource; + + resource = grab->pointer->focus_resource; + if (resource) + wl_pointer_send_motion(resource, time, sx, sy); +} + +static void +overlay_grab_button(struct wl_pointer_grab *grab, + uint32_t time, uint32_t button, uint32_t state_w) +{ + struct wl_resource *resource; + struct overlay *overlay = container_of(grab, struct overlay, grab); + struct wl_display *display; + enum wl_pointer_button_state state = state_w; + uint32_t serial; + + resource = grab->pointer->focus_resource; + if (resource) { + display = wl_client_get_display(resource->client); + serial = wl_display_get_serial(display); + wl_pointer_send_button(resource, serial, time, button, state); + } else { + overlay_close(overlay); + } +} + +static const struct wl_pointer_grab_interface overlay_grab_interface = { + overlay_grab_focus, + overlay_grab_motion, + overlay_grab_button, +}; + +static struct weston_output * +get_output_for_pointer(struct overlay *overlay) +{ + struct weston_output *output; + int x, y; + + x = wl_fixed_to_int(overlay->seat->pointer->x); + y = wl_fixed_to_int(overlay->seat->pointer->y); + + wl_list_for_each(output, &overlay->compositor->output_list, link) { + if (pixman_region32_contains_point(&output->region, + x, y, NULL)) + return output; + } + + return NULL; +} + +static void +overlay_configure(struct weston_surface *surface, int32_t sx, int32_t sy) +{ + struct overlay *overlay = surface->private; + struct weston_output *output; + int width, height; + + if (wl_list_empty(&surface->layer_link)) { + wl_list_insert(&overlay->layer.surface_list, + &surface->layer_link); + + wl_keyboard_set_focus(overlay->seat->keyboard, + &surface->surface); + + overlay->grab.interface = &overlay_grab_interface; + wl_pointer_start_grab(overlay->seat->pointer, &overlay->grab); + overlay->output = get_output_for_pointer(overlay); + } + + output = overlay->output; + width = surface->buffer_ref.buffer->width; + height = surface->buffer_ref.buffer->height; + + surface->geometry.x = output->x + (output->width - width) / 2; + surface->geometry.y = output->y + (output->height - height) / 2; + surface->geometry.width = surface->buffer_ref.buffer->width; + surface->geometry.height = surface->buffer_ref.buffer->height; + surface->geometry.dirty = 1; + + if (!weston_surface_is_mapped(surface)) + weston_surface_update_transform(surface); +} + +static void +overlay_handle_surface(struct wl_client *client, + struct wl_resource *resource, + struct wl_resource *surface_resource) +{ + struct overlay *overlay = resource->data; + + overlay->surface = surface_resource->data; + overlay->surface_destroy_listener.notify = handle_surface_destroy; + wl_signal_add(&surface_resource->destroy_signal, + &overlay->surface_destroy_listener); + + overlay->surface->configure = overlay_configure; + overlay->surface->private = overlay; +} + +static void +overlay_handle_close(struct wl_client *client, + struct wl_resource *resource) +{ + struct overlay *overlay = resource->data; + + overlay_close(overlay); +} + +static const struct overlay_interface overlay_implementation = { + overlay_handle_surface, + overlay_handle_close +}; + +static void +overlay_binding(struct wl_seat *_seat, + uint32_t time, uint32_t key, void *data) +{ + struct overlay *overlay = data; + + fprintf(stderr, "overlay binding pressed\n"); + + overlay->seat = _seat; + if (overlay->resource) + overlay_send_activate(overlay->resource); +} + +static void +handle_overlay_destroy(struct wl_resource *resource) +{ + struct overlay *overlay = resource->data; + + overlay->resource = NULL; + free(resource); +} + +static void +bind_overlay(struct wl_client *client, + void *data, uint32_t version, uint32_t id) +{ + struct overlay *overlay = data; + + fprintf(stderr, "client %p binds to overlay global\n", client); + + overlay->resource = + wl_client_add_object(client, &overlay_interface, + &overlay_implementation, id, overlay); + overlay->resource->destroy = handle_overlay_destroy; +} + +static void +overlay_destroy(struct wl_listener *listener, void *data) +{ + struct overlay *overlay = + container_of(listener, struct overlay, destroy_listener); + + wl_display_remove_global(overlay->compositor->wl_display, + overlay->global); + free(overlay); +} + +int +module_init(struct weston_compositor *compositor); + +WL_EXPORT int +module_init(struct weston_compositor *compositor) +{ + struct overlay *overlay; + + overlay = malloc(sizeof *overlay); + if (overlay == NULL) + return -1; + + overlay->compositor = compositor; + overlay->global = wl_display_add_global(compositor->wl_display, + &overlay_interface, + overlay, bind_overlay); + + overlay->destroy_listener.notify = overlay_destroy; + wl_signal_add(&compositor->destroy_signal, &overlay->destroy_listener); + + overlay->binding = + weston_compositor_add_key_binding(compositor, KEY_SPACE, + MODIFIER_SUPER, + overlay_binding, overlay); + + weston_layer_init(&overlay->layer, &compositor->cursor_layer.link); + + weston_log("overlay initialized\n"); + + return 0; +} diff --git a/overlay.xml b/overlay.xml new file mode 100644 index 0000000..0a73b7c --- /dev/null +++ b/overlay.xml @@ -0,0 +1,14 @@ +<protocol name="preflight"> + + <interface name="overlay" version="1"> + <request name="surface"> + <arg name="surface" type="object" interface="wl_surface"/> + </request> + + <request name="close"/> + + <event name="activate"/> + <event name="done"/> + </interface> + +</protocol> diff --git a/weston/compositor.h b/weston/compositor.h new file mode 100644 index 0000000..0638a3a --- /dev/null +++ b/weston/compositor.h @@ -0,0 +1,846 @@ +/* + * Copyright © 2008-2011 Kristian Høgsberg + * Copyright © 2012 Collabora, Ltd. + * + * Permission to use, copy, modify, distribute, and sell this software and + * its documentation for any purpose is hereby granted without fee, provided + * that the above copyright notice appear in all copies and that both that + * copyright notice and this permission notice appear in supporting + * documentation, and that the name of the copyright holders not be used in + * advertising or publicity pertaining to distribution of the software + * without specific, written prior permission. The copyright holders make + * no representations about the suitability of this software for any + * purpose. It is provided "as is" without express or implied warranty. + * + * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS + * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND + * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY + * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER + * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF + * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN + * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#ifndef _WAYLAND_SYSTEM_COMPOSITOR_H_ +#define _WAYLAND_SYSTEM_COMPOSITOR_H_ + +#include <pixman.h> +#include <xkbcommon/xkbcommon.h> +#include <wayland-server.h> + +#include "matrix.h" +#include "config-parser.h" + +#define ARRAY_LENGTH(a) (sizeof (a) / sizeof (a)[0]) + +#define container_of(ptr, type, member) ({ \ + const __typeof__( ((type *)0)->member ) *__mptr = (ptr); \ + (type *)( (char *)__mptr - offsetof(type,member) );}) + +struct weston_transform { + struct weston_matrix matrix; + struct wl_list link; +}; + +struct weston_surface; +struct shell_surface; +struct weston_seat; +struct weston_output; +struct input_method; + +enum weston_keyboard_modifier { + MODIFIER_CTRL = (1 << 0), + MODIFIER_ALT = (1 << 1), + MODIFIER_SUPER = (1 << 2), + MODIFIER_SHIFT = (1 << 3), +}; + +enum weston_led { + LED_NUM_LOCK = (1 << 0), + LED_CAPS_LOCK = (1 << 1), + LED_SCROLL_LOCK = (1 << 2), +}; + +struct weston_mode { + uint32_t flags; + int32_t width, height; + uint32_t refresh; + struct wl_list link; +}; + +struct weston_shell_client { + void (*send_configure)(struct weston_surface *surface, + uint32_t edges, int32_t width, int32_t height); +}; + +struct weston_shell_interface { + void *shell; /* either desktop or tablet */ + + struct shell_surface *(*create_shell_surface)(void *shell, + struct weston_surface *surface, + const struct weston_shell_client *client); + + void (*set_toplevel)(struct shell_surface *shsurf); + + void (*set_transient)(struct shell_surface *shsurf, + struct weston_surface *parent, + int x, int y, uint32_t flags); + void (*set_fullscreen)(struct shell_surface *shsurf, + uint32_t method, + uint32_t framerate, + struct weston_output *output); + int (*move)(struct shell_surface *shsurf, struct weston_seat *ws); + int (*resize)(struct shell_surface *shsurf, + struct weston_seat *ws, uint32_t edges); + +}; + +struct weston_border { + int32_t left, right, top, bottom; +}; + +struct weston_animation { + void (*frame)(struct weston_animation *animation, + struct weston_output *output, uint32_t msecs); + int frame_counter; + struct wl_list link; +}; + +struct weston_spring { + double k; + double friction; + double current; + double target; + double previous; + uint32_t timestamp; +}; + +enum { + ZOOM_FOCUS_POINTER, + ZOOM_FOCUS_TEXT +}; + +struct weston_fixed_point { + wl_fixed_t x, y; +}; + +struct weston_output_zoom { + int active; + uint32_t type; + float increment; + float level; + float max_level; + float trans_x, trans_y; + struct weston_animation animation_z; + struct weston_spring spring_z; + struct weston_animation animation_xy; + struct weston_spring spring_xy; + struct weston_fixed_point from; + struct weston_fixed_point to; + struct weston_fixed_point current; + struct weston_fixed_point text_cursor; +}; + +/* bit compatible with drm definitions. */ +enum dpms_enum { + WESTON_DPMS_ON, + WESTON_DPMS_STANDBY, + WESTON_DPMS_SUSPEND, + WESTON_DPMS_OFF +}; + +struct weston_output { + uint32_t id; + + void *renderer_state; + + struct wl_list link; + struct wl_list resource_list; + struct wl_global *global; + struct weston_compositor *compositor; + struct weston_matrix matrix; + struct wl_list animation_list; + int32_t x, y, width, height; + int32_t mm_width, mm_height; + struct weston_border border; + pixman_region32_t region; + pixman_region32_t previous_damage; + int repaint_needed; + int repaint_scheduled; + struct weston_output_zoom zoom; + int dirty; + struct wl_signal frame_signal; + uint32_t frame_time; + int disable_planes; + + char *make, *model; + uint32_t subpixel; + uint32_t transform; + + struct weston_mode *current; + struct weston_mode *origin; + struct wl_list mode_list; + + void (*repaint)(struct weston_output *output, + pixman_region32_t *damage); + void (*destroy)(struct weston_output *output); + void (*assign_planes)(struct weston_output *output); + int (*switch_mode)(struct weston_output *output, struct weston_mode *mode); + + /* backlight values are on 0-255 range, where higher is brighter */ + uint32_t backlight_current; + void (*set_backlight)(struct weston_output *output, uint32_t value); + void (*set_dpms)(struct weston_output *output, enum dpms_enum level); +}; + +struct weston_xkb_info { + struct xkb_keymap *keymap; + int keymap_fd; + size_t keymap_size; + char *keymap_area; + xkb_mod_index_t shift_mod; + xkb_mod_index_t caps_mod; + xkb_mod_index_t ctrl_mod; + xkb_mod_index_t alt_mod; + xkb_mod_index_t mod2_mod; + xkb_mod_index_t mod3_mod; + xkb_mod_index_t super_mod; + xkb_mod_index_t mod5_mod; + xkb_led_index_t num_led; + xkb_led_index_t caps_led; + xkb_led_index_t scroll_led; +}; + +struct weston_seat { + struct wl_seat seat; + struct wl_pointer pointer; + int has_pointer; + struct wl_keyboard keyboard; + int has_keyboard; + struct wl_touch touch; + int has_touch; + + struct weston_compositor *compositor; + struct weston_surface *sprite; + struct wl_listener sprite_destroy_listener; + struct weston_surface *drag_surface; + struct wl_listener drag_surface_destroy_listener; + int32_t hotspot_x, hotspot_y; + struct wl_list link; + enum weston_keyboard_modifier modifier_state; + struct wl_surface *saved_kbd_focus; + struct wl_listener saved_kbd_focus_listener; + + uint32_t num_tp; + + struct wl_listener new_drag_icon_listener; + + void (*led_update)(struct weston_seat *ws, enum weston_led leds); + + struct weston_xkb_info xkb_info; + struct { + struct xkb_state *state; + enum weston_led leds; + } xkb_state; + + struct input_method *input_method; +}; + +enum { + WESTON_COMPOSITOR_ACTIVE, + WESTON_COMPOSITOR_IDLE, /* shell->unlock called on activity */ + WESTON_COMPOSITOR_SLEEPING /* no rendering, no frame events */ +}; + +struct weston_layer { + struct wl_list surface_list; + struct wl_list link; +}; + +struct weston_plane { + pixman_region32_t damage; + pixman_region32_t opaque; + int32_t x, y; +}; + +struct weston_renderer { + int (*read_pixels)(struct weston_output *output, + pixman_format_code_t format, void *pixels, + uint32_t x, uint32_t y, + uint32_t width, uint32_t height); + void (*repaint_output)(struct weston_output *output, + pixman_region32_t *output_damage); + void (*flush_damage)(struct weston_surface *surface); + void (*attach)(struct weston_surface *es, struct wl_buffer *buffer); + int (*create_surface)(struct weston_surface *surface); + void (*surface_set_color)(struct weston_surface *surface, + float red, float green, + float blue, float alpha); + void (*destroy_surface)(struct weston_surface *surface); + void (*destroy)(struct weston_compositor *ec); +}; + +struct weston_compositor { + struct wl_signal destroy_signal; + + struct wl_display *wl_display; + struct weston_shell_interface shell_interface; + + struct wl_signal activate_signal; + struct wl_signal kill_signal; + struct wl_signal lock_signal; + struct wl_signal unlock_signal; + + struct wl_signal show_input_panel_signal; + struct wl_signal hide_input_panel_signal; + + struct wl_signal seat_created_signal; + + struct wl_event_loop *input_loop; + struct wl_event_source *input_loop_source; + + struct weston_layer fade_layer; + struct weston_layer cursor_layer; + + struct wl_list output_list; + struct wl_list seat_list; + struct wl_list layer_list; + struct wl_list surface_list; + struct wl_list key_binding_list; + struct wl_list button_binding_list; + struct wl_list axis_binding_list; + struct wl_list debug_binding_list; + struct { + struct weston_spring spring; + struct weston_animation animation; + struct weston_surface *surface; + } fade; + + uint32_t state; + struct wl_event_source *idle_source; + uint32_t idle_inhibit; + int option_idle_time; /* default timeout, s */ + int idle_time; /* effective timeout, s */ + + /* Repaint state. */ + struct wl_array vertices; + struct wl_array indices; /* only used in compositor-wayland */ + struct wl_array vtxcnt; + struct weston_plane primary_plane; + int fan_debug; + + uint32_t focus; + + struct weston_renderer *renderer; + + pixman_format_code_t read_format; + + void (*destroy)(struct weston_compositor *ec); + void (*restore)(struct weston_compositor *ec); + int (*authenticate)(struct weston_compositor *c, uint32_t id); + + void (*ping_handler)(struct weston_surface *surface, uint32_t serial); + + int launcher_sock; + + uint32_t output_id_pool; + + struct xkb_rule_names xkb_names; + struct xkb_context *xkb_context; + struct weston_xkb_info xkb_info; +}; + +struct weston_buffer_reference { + struct wl_buffer *buffer; + struct wl_listener destroy_listener; +}; + +struct weston_region { + struct wl_resource resource; + pixman_region32_t region; +}; + +/* Using weston_surface transformations + * + * To add a transformation to a surface, create a struct weston_transform, and + * add it to the list surface->geometry.transformation_list. Whenever you + * change the list, anything under surface->geometry, or anything in the + * weston_transforms linked into the list, you must set + * surface->geometry.dirty = 1. + * + * The order in the list defines the order of transformations. Let the list + * contain the transformation matrices M1, ..., Mn as head to tail. The + * transformation is applied to surface-local coordinate vector p as + * P = Mn * ... * M2 * M1 * p + * to produce the global coordinate vector P. The total transform + * Mn * ... * M2 * M1 + * is cached in surface->transform.matrix, and the inverse of it in + * surface->transform.inverse. + * + * The list always contains surface->transform.position transformation, which + * is the translation by surface->geometry.x and y. + * + * If you want to apply a transformation in local coordinates, add your + * weston_transform to the head of the list. If you want to apply a + * transformation in global coordinates, add it to the tail of the list. + */ + +struct weston_surface { + struct wl_surface surface; + struct weston_compositor *compositor; + pixman_region32_t clip; + pixman_region32_t damage; + pixman_region32_t opaque; + pixman_region32_t input; + struct wl_list link; + struct wl_list layer_link; + float alpha; + struct weston_plane *plane; + + void *renderer_state; + + /* Surface geometry state, mutable. + * If you change anything, set dirty = 1. + * That includes the transformations referenced from the list. + */ + struct { + float x, y; /* surface translation on display */ + int32_t width, height; + + /* struct weston_transform */ + struct wl_list transformation_list; + + int dirty; + } geometry; + + /* State derived from geometry state, read-only. + * This is updated by weston_surface_update_transform(). + */ + struct { + pixman_region32_t boundingbox; + pixman_region32_t opaque; + + /* matrix and inverse are used only if enabled = 1. + * If enabled = 0, use x, y, width, height directly. + */ + int enabled; + struct weston_matrix matrix; + struct weston_matrix inverse; + + struct weston_transform position; /* matrix from x, y */ + } transform; + + /* + * Which output to vsync this surface to. + * Used to determine, whether to send or queue frame events. + * Must be NULL, if 'link' is not in weston_compositor::surface_list. + */ + struct weston_output *output; + + /* + * A more complete representation of all outputs this surface is + * displayed on. + */ + uint32_t output_mask; + + struct wl_list frame_callback_list; + + struct weston_buffer_reference buffer_ref; + uint32_t buffer_transform; + int keep_buffer; /* bool for backends to prevent early release */ + + /* All the pending state, that wl_surface.commit will apply. */ + struct { + /* wl_surface.attach */ + int remove_contents; + struct wl_buffer *buffer; + struct wl_listener buffer_destroy_listener; + int32_t sx; + int32_t sy; + + /* wl_surface.damage */ + pixman_region32_t damage; + + /* wl_surface.set_opaque_region */ + pixman_region32_t opaque; + + /* wl_surface.set_input_region */ + pixman_region32_t input; + + /* wl_surface.frame */ + struct wl_list frame_callback_list; + + /* wl_surface.set_buffer_transform */ + uint32_t buffer_transform; + } pending; + + /* + * If non-NULL, this function will be called on surface::attach after + * a new buffer has been set up for this surface. The integer params + * are the sx and sy paramerters supplied to surface::attach . + */ + void (*configure)(struct weston_surface *es, int32_t sx, int32_t sy); + void *private; +}; + +enum weston_key_state_update { + STATE_UPDATE_AUTOMATIC, + STATE_UPDATE_NONE, +}; + +void +weston_surface_update_transform(struct weston_surface *surface); + +void +weston_surface_to_global_fixed(struct weston_surface *surface, + wl_fixed_t sx, wl_fixed_t sy, + wl_fixed_t *x, wl_fixed_t *y); +void +weston_surface_to_global_float(struct weston_surface *surface, + float sx, float sy, float *x, float *y); + +void +weston_surface_from_global_float(struct weston_surface *surface, + float x, float y, float *sx, float *sy); +void +weston_surface_from_global(struct weston_surface *surface, + int32_t x, int32_t y, int32_t *sx, int32_t *sy); +void +weston_surface_from_global_fixed(struct weston_surface *surface, + wl_fixed_t x, wl_fixed_t y, + wl_fixed_t *sx, wl_fixed_t *sy); +int32_t +weston_surface_buffer_width(struct weston_surface *surface); +int32_t +weston_surface_buffer_height(struct weston_surface *surface); + +WL_EXPORT void +weston_surface_to_buffer_float(struct weston_surface *surface, + float x, float y, float *bx, float *by); +pixman_box32_t +weston_surface_to_buffer_rect(struct weston_surface *surface, + pixman_box32_t rect); + +void +weston_spring_init(struct weston_spring *spring, + double k, double current, double target); +void +weston_spring_update(struct weston_spring *spring, uint32_t msec); +int +weston_spring_done(struct weston_spring *spring); + +void +weston_surface_activate(struct weston_surface *surface, + struct weston_seat *seat); +void +notify_motion(struct weston_seat *seat, uint32_t time, + wl_fixed_t x, wl_fixed_t y); +void +notify_button(struct weston_seat *seat, uint32_t time, int32_t button, + enum wl_pointer_button_state state); +void +notify_axis(struct weston_seat *seat, uint32_t time, uint32_t axis, + wl_fixed_t value); +void +notify_key(struct weston_seat *seat, uint32_t time, uint32_t key, + enum wl_keyboard_key_state state, + enum weston_key_state_update update_state); +void +notify_modifiers(struct weston_seat *seat, uint32_t serial); + +void +notify_pointer_focus(struct weston_seat *seat, struct weston_output *output, + wl_fixed_t x, wl_fixed_t y); + +void +notify_keyboard_focus_in(struct weston_seat *seat, struct wl_array *keys, + enum weston_key_state_update update_state); +void +notify_keyboard_focus_out(struct weston_seat *seat); + +void +notify_touch(struct weston_seat *seat, uint32_t time, int touch_id, + wl_fixed_t x, wl_fixed_t y, int touch_type); + +void +weston_layer_init(struct weston_layer *layer, struct wl_list *below); + +void +weston_plane_init(struct weston_plane *plane, int32_t x, int32_t y); +void +weston_plane_release(struct weston_plane *plane); + +void +weston_output_finish_frame(struct weston_output *output, uint32_t msecs); +void +weston_output_schedule_repaint(struct weston_output *output); +void +weston_output_damage(struct weston_output *output); +void +weston_compositor_schedule_repaint(struct weston_compositor *compositor); +void +weston_compositor_fade(struct weston_compositor *compositor, float tint); +void +weston_compositor_damage_all(struct weston_compositor *compositor); +void +weston_compositor_unlock(struct weston_compositor *compositor); +void +weston_compositor_wake(struct weston_compositor *compositor); +void +weston_compositor_activity(struct weston_compositor *compositor); +void +weston_compositor_update_drag_surfaces(struct weston_compositor *compositor); + + +struct weston_binding; +typedef void (*weston_key_binding_handler_t)(struct wl_seat *seat, + uint32_t time, uint32_t key, + void *data); +struct weston_binding * +weston_compositor_add_key_binding(struct weston_compositor *compositor, + uint32_t key, + enum weston_keyboard_modifier modifier, + weston_key_binding_handler_t binding, + void *data); + +typedef void (*weston_button_binding_handler_t)(struct wl_seat *seat, + uint32_t time, uint32_t button, + void *data); +struct weston_binding * +weston_compositor_add_button_binding(struct weston_compositor *compositor, + uint32_t button, + enum weston_keyboard_modifier modifier, + weston_button_binding_handler_t binding, + void *data); + +typedef void (*weston_axis_binding_handler_t)(struct wl_seat *seat, + uint32_t time, uint32_t axis, + wl_fixed_t value, void *data); +struct weston_binding * +weston_compositor_add_axis_binding(struct weston_compositor *compositor, + uint32_t axis, + enum weston_keyboard_modifier modifier, + weston_axis_binding_handler_t binding, + void *data); +struct weston_binding * +weston_compositor_add_debug_binding(struct weston_compositor *compositor, + uint32_t key, + weston_key_binding_handler_t binding, + void *data); +void +weston_binding_destroy(struct weston_binding *binding); + +void +weston_binding_list_destroy_all(struct wl_list *list); + +void +weston_compositor_run_key_binding(struct weston_compositor *compositor, + struct weston_seat *seat, uint32_t time, + uint32_t key, + enum wl_keyboard_key_state state); +void +weston_compositor_run_button_binding(struct weston_compositor *compositor, + struct weston_seat *seat, uint32_t time, + uint32_t button, + enum wl_pointer_button_state value); +void +weston_compositor_run_axis_binding(struct weston_compositor *compositor, + struct weston_seat *seat, uint32_t time, + uint32_t axis, int32_t value); +int +weston_compositor_run_debug_binding(struct weston_compositor *compositor, + struct weston_seat *seat, uint32_t time, + uint32_t key, + enum wl_keyboard_key_state state); + +int +weston_environment_get_fd(const char *env); + +struct wl_list * +weston_compositor_top(struct weston_compositor *compositor); + +struct weston_surface * +weston_surface_create(struct weston_compositor *compositor); + +void +weston_surface_configure(struct weston_surface *surface, + float x, float y, int width, int height); + +void +weston_surface_restack(struct weston_surface *surface, struct wl_list *below); + +void +weston_surface_set_position(struct weston_surface *surface, + float x, float y); + +int +weston_surface_is_mapped(struct weston_surface *surface); + +void +weston_surface_schedule_repaint(struct weston_surface *surface); + +void +weston_surface_damage(struct weston_surface *surface); + +void +weston_surface_damage_below(struct weston_surface *surface); + +void +weston_surface_move_to_plane(struct weston_surface *surface, + struct weston_plane *plane); +void +weston_surface_unmap(struct weston_surface *surface); + +void +weston_buffer_post_release(struct wl_buffer *buffer); + +void +weston_buffer_reference(struct weston_buffer_reference *ref, + struct wl_buffer *buffer); + +uint32_t +weston_compositor_get_time(void); + +int +weston_compositor_init(struct weston_compositor *ec, struct wl_display *display, + int argc, char *argv[], const char *config_file); +void +weston_compositor_shutdown(struct weston_compositor *ec); +void +weston_text_cursor_position_notify(struct weston_surface *surface, + wl_fixed_t x, wl_fixed_t y); +void +weston_output_init_zoom(struct weston_output *output); +void +weston_output_update_zoom(struct weston_output *output, uint32_t type); +void +weston_output_update_matrix(struct weston_output *output); +void +weston_output_move(struct weston_output *output, int x, int y); +void +weston_output_init(struct weston_output *output, struct weston_compositor *c, + int x, int y, int width, int height, uint32_t transform); +void +weston_output_destroy(struct weston_output *output); + +void +weston_seat_init(struct weston_seat *seat, struct weston_compositor *ec); +void +weston_seat_init_pointer(struct weston_seat *seat); +void +weston_seat_init_keyboard(struct weston_seat *seat, struct xkb_keymap *keymap); +void +weston_seat_init_touch(struct weston_seat *seat); + +void +weston_seat_release(struct weston_seat *seat); + +/* String literal of spaces, the same width as the timestamp. */ +#define STAMP_SPACE " " + +void +weston_log_file_open(const char *filename); +void +weston_log_file_close(void); +int +weston_log(const char *fmt, ...) + __attribute__ ((format (printf, 1, 2))); +int +weston_log_continue(const char *fmt, ...) + __attribute__ ((format (printf, 1, 2))); + +enum { + TTY_ENTER_VT, + TTY_LEAVE_VT +}; + +typedef void (*tty_vt_func_t)(struct weston_compositor *compositor, int event); + +struct tty * +tty_create(struct weston_compositor *compositor, + tty_vt_func_t vt_func, int tty_nr); + +void +tty_destroy(struct tty *tty); + +void +tty_reset(struct tty *tty); + +int +tty_activate_vt(struct tty *tty, int vt); + +void +screenshooter_create(struct weston_compositor *ec); + +struct clipboard * +clipboard_create(struct weston_seat *seat); + +void +text_cursor_position_notifier_create(struct weston_compositor *ec); + +int +text_backend_init(struct weston_compositor *ec); + +struct weston_process; +typedef void (*weston_process_cleanup_func_t)(struct weston_process *process, + int status); + +struct weston_process { + pid_t pid; + weston_process_cleanup_func_t cleanup; + struct wl_list link; +}; + +struct wl_client * +weston_client_launch(struct weston_compositor *compositor, + struct weston_process *proc, + const char *path, + weston_process_cleanup_func_t cleanup); + +void +weston_watch_process(struct weston_process *process); + +struct weston_surface_animation; +typedef void (*weston_surface_animation_done_func_t)(struct weston_surface_animation *animation, void *data); + +struct weston_surface_animation * +weston_zoom_run(struct weston_surface *surface, float start, float stop, + weston_surface_animation_done_func_t done, void *data); + +struct weston_surface_animation * +weston_fade_run(struct weston_surface *surface, + weston_surface_animation_done_func_t done, void *data); +struct weston_surface_animation * +weston_slide_run(struct weston_surface *surface, float start, float stop, + weston_surface_animation_done_func_t done, void *data); + +void +weston_surface_set_color(struct weston_surface *surface, + float red, float green, float blue, float alpha); + +void +weston_surface_destroy(struct weston_surface *surface); + +int +weston_output_switch_mode(struct weston_output *output, struct weston_mode *mode); + +int +noop_renderer_init(struct weston_compositor *ec); + +struct weston_compositor * +backend_init(struct wl_display *display, int argc, char *argv[], + const char *config_file); + +int +module_init(struct weston_compositor *compositor); + +void +weston_transformed_coord(int width, int height, + enum wl_output_transform transform, + float sx, float sy, float *bx, float *by); +pixman_box32_t +weston_transformed_rect(int width, int height, + enum wl_output_transform transform, + pixman_box32_t rect); + +#endif diff --git a/weston/config-parser.h b/weston/config-parser.h new file mode 100644 index 0000000..7fa9c3f --- /dev/null +++ b/weston/config-parser.h @@ -0,0 +1,73 @@ +/* + * Copyright © 2008 Kristian Høgsberg + * + * Permission to use, copy, modify, distribute, and sell this software and its + * documentation for any purpose is hereby granted without fee, provided that + * the above copyright notice appear in all copies and that both that copyright + * notice and this permission notice appear in supporting documentation, and + * that the name of the copyright holders not be used in advertising or + * publicity pertaining to distribution of the software without specific, + * written prior permission. The copyright holders make no representations + * about the suitability of this software for any purpose. It is provided "as + * is" without express or implied warranty. + * + * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, + * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO + * EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY SPECIAL, INDIRECT OR + * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, + * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER + * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE + * OF THIS SOFTWARE. + */ + +#ifndef CONFIGPARSER_H +#define CONFIGPARSER_H + +enum config_key_type { + CONFIG_KEY_INTEGER, /* typeof data = int */ + CONFIG_KEY_UNSIGNED_INTEGER, /* typeof data = unsigned int */ + CONFIG_KEY_STRING, /* typeof data = char* */ + CONFIG_KEY_BOOLEAN /* typeof data = int */ +}; + +struct config_key { + const char *name; + enum config_key_type type; + void *data; +}; + +struct config_section { + const char *name; + const struct config_key *keys; + int num_keys; + void (*done)(void *data); +}; + +int +parse_config_file(const char *path, + const struct config_section *sections, int num_sections, + void *data); + +char * +config_file_path(const char *name); + +enum weston_option_type { + WESTON_OPTION_INTEGER, + WESTON_OPTION_UNSIGNED_INTEGER, + WESTON_OPTION_STRING, + WESTON_OPTION_BOOLEAN +}; + +struct weston_option { + enum weston_option_type type; + const char *name; + int short_name; + void *data; +}; + +int +parse_options(const struct weston_option *options, + int count, int argc, char *argv[]); + +#endif /* CONFIGPARSER_H */ + diff --git a/weston/matrix.h b/weston/matrix.h new file mode 100644 index 0000000..47354f6 --- /dev/null +++ b/weston/matrix.h @@ -0,0 +1,74 @@ +/* + * Copyright © 2008-2011 Kristian Høgsberg + * Copyright © 2012 Collabora, Ltd. + * + * Permission to use, copy, modify, distribute, and sell this software and + * its documentation for any purpose is hereby granted without fee, provided + * that the above copyright notice appear in all copies and that both that + * copyright notice and this permission notice appear in supporting + * documentation, and that the name of the copyright holders not be used in + * advertising or publicity pertaining to distribution of the software + * without specific, written prior permission. The copyright holders make + * no representations about the suitability of this software for any + * purpose. It is provided "as is" without express or implied warranty. + * + * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS + * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND + * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY + * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER + * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF + * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN + * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#ifndef WESTON_MATRIX_H +#define WESTON_MATRIX_H + +enum weston_matrix_transform_type { + WESTON_MATRIX_TRANSFORM_TRANSLATE = (1 << 0), + WESTON_MATRIX_TRANSFORM_SCALE = (1 << 1), + WESTON_MATRIX_TRANSFORM_ROTATE = (1 << 2), + WESTON_MATRIX_TRANSFORM_OTHER = (1 << 3), +}; + +struct weston_matrix { + float d[16]; + unsigned int type; +}; + +struct weston_vector { + float f[4]; +}; + +void +weston_matrix_init(struct weston_matrix *matrix); +void +weston_matrix_multiply(struct weston_matrix *m, const struct weston_matrix *n); +void +weston_matrix_scale(struct weston_matrix *matrix, float x, float y, float z); +void +weston_matrix_translate(struct weston_matrix *matrix, + float x, float y, float z); +void +weston_matrix_rotate_xy(struct weston_matrix *matrix, float cos, float sin); +void +weston_matrix_transform(struct weston_matrix *matrix, struct weston_vector *v); + +int +weston_matrix_invert(struct weston_matrix *inverse, + const struct weston_matrix *matrix); + +#ifdef UNIT_TEST +# define MATRIX_TEST_EXPORT WL_EXPORT + +int +matrix_invert(double *A, unsigned *p, const struct weston_matrix *matrix); + +void +inverse_transform(const double *LU, const unsigned *p, float *v); + +#else +# define MATRIX_TEST_EXPORT static +#endif + +#endif /* WESTON_MATRIX_H */ |