Port ico-uxf-weston-plugin to use Weston 1.0.6 plugin API. 88/3488/1
authorOssama Othman <ossama.othman@intel.com>
Tue, 30 Apr 2013 21:37:25 +0000 (14:37 -0700)
committerOssama Othman <ossama.othman@intel.com>
Tue, 30 Apr 2013 21:37:25 +0000 (14:37 -0700)
Change-Id: I7206280c389318a4b6492e36871c11bc2739f0ed
Signed-off-by: Ossama Othman <ossama.othman@intel.com>
13 files changed:
configure.ac
packaging/ico-uxf-weston-plugin.spec
shared [deleted symlink]
src/Makefile.am
src/compositor.h [deleted file]
src/config-parser.c [deleted file]
src/config-parser.h [deleted file]
src/ico_input_mgr.c
src/ico_ivi_common.c
src/ico_ivi_shell.c
src/ico_plugin_loader.c
src/ico_window_mgr.c
src/matrix.h [deleted file]

index f50ba04..0cf5a51 100644 (file)
@@ -32,17 +32,7 @@ AC_CHECK_HEADERS([execinfo.h])
 
 AC_CHECK_FUNCS([mkostemp strchrnul])
 
-PKG_CHECK_MODULES(COMPOSITOR,
-                 [wayland-server egl >= 7.10 glesv2 xkbcommon pixman-1])
-
-AC_ARG_ENABLE(setuid-install, [  --enable-setuid-install],,
-             enable_setuid_install=yes)
-AM_CONDITIONAL(ENABLE_SETUID_INSTALL, test x$enable_setuid_install = xyes)
-
-COMPOSITOR_LIBS="$COMPOSITOR_LIBS $IMAGE_LIBS"
-COMPOSITOR_CFLAGS="$COMPOSITOR_CFLAGS $IMAGE_CFLAGS"
-
-AM_CONDITIONAL(ENABLE_DESKTOP_SHELL, true)
+PKG_CHECK_MODULES([PLUGIN], [weston >= 1.0.6 pixman-1 xkbcommon])
 
 if test "x$GCC" = "xyes"; then
        my_common_gcc_flags="-Wall -Wextra -Wno-unused-parameter \
index 05db689..1ea0821 100644 (file)
@@ -7,13 +7,7 @@ License:    MIT
 URL:        ""
 Source0:    %{name}-%{version}.tar.bz2
 
-BuildRequires: pkgconfig(wayland-server) >= 1.0
-BuildRequires: pkgconfig(wayland-client) >= 1.0
-BuildRequires: pkgconfig(wayland-egl)
-BuildRequires: pkgconfig(egl)
-BuildRequires: pkgconfig(glesv2)
-BuildRequires: pkgconfig(xkbcommon)
-BuildRequires: pkgconfig(pixman-1)
+BuildRequires: pkgconfig(weston) >= 1.0.6
 BuildRequires: pkgconfig(eina)
 BuildRequires: pkgconfig(evas)
 BuildRequires: pkgconfig(eina)
@@ -21,7 +15,7 @@ BuildRequires: pkgconfig(elementary)
 BuildRequires: pkgconfig(ecore-wayland)
 BuildRequires: aul-devel
 BuildRequires: ecore-devel
-Requires: weston >= 1.0
+Requires: weston >= 1.0.6
 
 %description
 Weston Plugins for IVI
diff --git a/shared b/shared
deleted file mode 120000 (symlink)
index e831038..0000000
--- a/shared
+++ /dev/null
@@ -1 +0,0 @@
-src
\ No newline at end of file
index 9401246..4031d79 100644 (file)
@@ -10,8 +10,8 @@ includedir = /usr/include/ico-uxf-weston-plugin
 libico_uxf_weston_plugin_la_LIBADD = -lrt -lm
 libico_uxf_weston_plugin_la_LDFLAGS = -version-info 0:5:0
 libico_uxf_weston_plugin_la_SOURCES =          \
-       ico_ivi_shell-protocol.c                        \
-       ico_window_mgr-protocol.c                       \
+       ico_ivi_shell-protocol.c                \
+       ico_window_mgr-protocol.c               \
        ico_input_mgr-protocol.c
 
 AM_CPPFLAGS =                                  \
@@ -41,59 +41,58 @@ module_LTLIBRARIES =                \
 # Weston Plugin Loader
 ico_plugin_loader = ico_plugin_loader.la
 ico_plugin_loader_la_LDFLAGS = -module -avoid-version
-ico_plugin_loader_la_LIBADD = $(COMPOSITOR_LIBS)
-ico_plugin_loader_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(COMPOSITOR_CFLAGS)
+ico_plugin_loader_la_LIBADD = $(PLUGIN_LIBS)
+ico_plugin_loader_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(PLUGIN_CFLAGS)
 ico_plugin_loader_la_SOURCES =          \
-       ico_plugin_loader.c ../shared/config-parser.c
+       ico_plugin_loader.c
 
 # IVI Common Functions
 ico_ivi_common = ico_ivi_common.la
 ico_ivi_common_la_LDFLAGS = -module -avoid-version
-ico_ivi_common_la_LIBADD = $(COMPOSITOR_LIBS)
-ico_ivi_common_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(COMPOSITOR_CFLAGS)
+ico_ivi_common_la_LIBADD = $(PLUGIN_LIBS)
+ico_ivi_common_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(PLUGIN_CFLAGS)
 ico_ivi_common_la_SOURCES =          \
-       ico_ivi_common.c ../shared/config-parser.c
+       ico_ivi_common.c
 
 # IVI-Shell
 ico_ivi_shell = ico_ivi_shell.la
 ico_ivi_shell_la_LDFLAGS = -module -avoid-version
-ico_ivi_shell_la_LIBADD = $(COMPOSITOR_LIBS)
-ico_ivi_shell_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(COMPOSITOR_CFLAGS)
+ico_ivi_shell_la_LIBADD = $(PLUGIN_LIBS)
+ico_ivi_shell_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(PLUGIN_CFLAGS)
 ico_ivi_shell_la_SOURCES =                     \
-       ico_ivi_shell.c                                 \
-       ../shared/config-parser.c               \
+       ico_ivi_shell.c                         \
        ico_ivi_shell-protocol.c                \
        ico_ivi_shell-server-protocol.h
 
 # Multi Window Manager
 ico_window_mgr = ico_window_mgr.la
 ico_window_mgr_la_LDFLAGS = -module -avoid-version
-ico_window_mgr_la_LIBADD = $(COMPOSITOR_LIBS) $(AUL_LIBS)
-ico_window_mgr_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(COMPOSITOR_CFLAGS)
+ico_window_mgr_la_LIBADD = $(PLUGIN_LIBS) $(AUL_LIBS)
+ico_window_mgr_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(PLUGIN_CFLAGS)
 ico_window_mgr_la_SOURCES =                    \
-       ico_window_mgr.c                                \
+       ico_window_mgr.c                        \
        ico_window_mgr-protocol.c               \
        ico_window_mgr-server-protocol.h
 
 # Multi Input Manager
 ico_input_mgr = ico_input_mgr.la
 ico_input_mgr_la_LDFLAGS = -module -avoid-version
-ico_input_mgr_la_LIBADD = $(COMPOSITOR_LIBS)
-ico_input_mgr_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(COMPOSITOR_CFLAGS)
+ico_input_mgr_la_LIBADD = $(PLUGIN_LIBS)
+ico_input_mgr_la_CFLAGS = $(GCC_CFLAGS) $(EXT_CFLAGS) $(PLUGIN_CFLAGS)
 ico_input_mgr_la_SOURCES =                     \
-       ico_input_mgr.c                                 \
+       ico_input_mgr.c                         \
        ico_input_mgr-protocol.c                \
        ico_input_mgr-server-protocol.h
 
 # Wayland protocol(Build by wayland-scanner)
-BUILT_SOURCES =                                                        \
-       ico_ivi_shell-protocol.c                        \
+BUILT_SOURCES =                                        \
+       ico_ivi_shell-protocol.c                \
        ico_ivi_shell-server-protocol.h         \
        ico_ivi_shell-client-protocol.h         \
-       ico_window_mgr-protocol.c                       \
+       ico_window_mgr-protocol.c               \
        ico_window_mgr-server-protocol.h        \
        ico_window_mgr-client-protocol.h        \
-       ico_input_mgr-protocol.c                        \
+       ico_input_mgr-protocol.c                \
        ico_input_mgr-server-protocol.h         \
        ico_input_mgr-client-protocol.h         \
        git-version.h
diff --git a/src/compositor.h b/src/compositor.h
deleted file mode 100644 (file)
index d2ae587..0000000
+++ /dev/null
@@ -1,841 +0,0 @@
-/*
- * 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 <GLES2/gl2.h>
-#include <GLES2/gl2ext.h>
-#include <EGL/egl.h>
-#include <EGL/eglext.h>
-
-/* #include "version.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);
-    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;
-
-    EGLSurface egl_surface;
-    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;
-    int current_buffer;
-    pixman_region32_t buffer_damage[2];
-    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;
-};
-
-struct weston_shader {
-    GLuint program;
-    GLuint vertex_shader, fragment_shader;
-    GLint proj_uniform;
-    GLint tex_uniforms[3];
-    GLint alpha_uniform;
-    GLint color_uniform;
-};
-
-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 {
-    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);
-    void (*destroy_surface)(struct weston_surface *surface);
-};
-
-struct weston_compositor {
-    struct wl_signal destroy_signal;
-
-    EGLDisplay egl_display;
-    EGLContext egl_context;
-    EGLConfig egl_config;
-    struct weston_shader texture_shader_rgba;
-    struct weston_shader texture_shader_rgbx;
-    struct weston_shader texture_shader_egl_external;
-    struct weston_shader texture_shader_y_uv;
-    struct weston_shader texture_shader_y_u_v;
-    struct weston_shader texture_shader_y_xuxv;
-    struct weston_shader solid_shader;
-    struct weston_shader *current_shader;
-    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_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 {
-        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;
-
-    PFNGLEGLIMAGETARGETRENDERBUFFERSTORAGEOESPROC
-        image_target_renderbuffer_storage;
-    PFNGLEGLIMAGETARGETTEXTURE2DOESPROC image_target_texture_2d;
-    PFNEGLCREATEIMAGEKHRPROC create_image;
-    PFNEGLDESTROYIMAGEKHRPROC destroy_image;
-
-    int has_unpack_subimage;
-    GLenum read_format;
-
-    PFNEGLBINDWAYLANDDISPLAYWL bind_display;
-    PFNEGLUNBINDWAYLANDDISPLAYWL unbind_display;
-    PFNEGLQUERYWAYLANDBUFFERWL query_buffer;
-    int has_bind_display;
-
-    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_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;
-    GLuint textures[3];
-    int num_textures;
-    pixman_region32_t clip;
-    pixman_region32_t damage;
-    pixman_region32_t opaque;
-    pixman_region32_t input;
-    int32_t pitch;
-    struct wl_list link;
-    struct wl_list layer_link;
-    struct weston_shader *shader;
-    GLfloat color[4];
-    float alpha;
-    struct weston_plane *plane;
-
-    /* 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;
-
-    EGLImageKHR images[3];
-    GLenum target;
-    int num_images;
-
-    struct wl_buffer *buffer;
-    struct wl_listener buffer_destroy_listener;
-
-    /* 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;
-    } 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_version(int *major, int *minor, int *micro);
-
-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);
-
-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);
-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_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);
-
-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);
-int
-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);
-
-void
-text_model_factory_create(struct weston_compositor *ec);
-
-void
-input_method_create(struct weston_compositor *ec,
-            struct weston_seat *seat);
-
-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
-gles2_renderer_init(struct weston_compositor *ec);
-void
-gles2_renderer_destroy(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);
-
-#endif
diff --git a/src/config-parser.c b/src/config-parser.c
deleted file mode 100644 (file)
index 95c6cf8..0000000
+++ /dev/null
@@ -1,187 +0,0 @@
-/*
- * Copyright © 2011 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 <stdio.h>
-#include <stdlib.h>
-#include <assert.h>
-#include <ctype.h>
-
-#include "config-parser.h"
-
-static int
-handle_key(const struct config_key *key, const char *value)
-{
-    char *end, *s;
-    int i, len;
-    unsigned int ui;
-    
-    switch (key->type) {
-    case CONFIG_KEY_INTEGER:
-        i = strtol(value, &end, 0);
-        if (*end != '\n') {
-            fprintf(stderr, "invalid integer: %s\n", value);
-            return -1;
-        }
-        *(int *)key->data = i;
-        return 0;
-
-    case CONFIG_KEY_UNSIGNED_INTEGER:
-        ui = strtoul(value, &end, 0);
-        if (*end != '\n') {
-            fprintf(stderr, "invalid integer: %s\n", value);
-            return -1;
-        }
-        *(unsigned int *)key->data = ui;
-        return 0;
-
-    case CONFIG_KEY_STRING:
-        len = strlen(value);
-        while (len > 0 && isspace(value[len - 1]))
-            len--;
-        s = malloc(len + 1);
-        if (s == NULL)
-            return -1;
-        memcpy(s, value, len);
-        s[len] = '\0';
-        *(char **)key->data = s;
-        return 0;
-
-    case CONFIG_KEY_BOOLEAN:
-        if (strcmp(value, "false\n") == 0)
-            *(int *)key->data = 0;
-        else if (strcmp(value, "true\n") == 0)
-            *(int *)key->data = 1;
-        else {
-            fprintf(stderr, "invalid bool: %s\n", value);
-            return -1;
-        }
-        return 0;
-
-    default:
-        assert(0);
-        break;
-    }
-
-    return -1;
-}
-
-int
-parse_config_file(const char *path,
-          const struct config_section *sections, int num_sections,
-          void *data)
-{
-    FILE *fp;
-    char line[512], *p;
-    const struct config_section *current = NULL;
-    int i;
-
-    fp = fopen(path, "r");
-    if (fp == NULL) {
-        fprintf(stderr, "couldn't open %s\n", path);
-        return -1;
-    }
-
-    while (fgets(line, sizeof line, fp)) {
-        if (line[0] == '#' || line[0] == '\n') {
-            continue;
-        } if (line[0] == '[') {
-            p = strchr(&line[1], ']');
-            if (!p || p[1] != '\n') {
-                fprintf(stderr, "malformed "
-                    "section header: %s\n", line);
-                fclose(fp);
-                return -1;
-            }
-            if (current && current->done)
-                current->done(data);
-            p[0] = '\0';
-            for (i = 0; i < num_sections; i++) {
-                if (strcmp(sections[i].name, &line[1]) == 0) {
-                    current = &sections[i];
-                    break;
-                }
-            }
-            if (i == num_sections)
-                current = NULL;
-        } else if (p = strchr(line, '='), p != NULL) {
-            if (current == NULL)
-                continue;
-            p[0] = '\0';
-            for (i = 0; i < current->num_keys; i++) {
-                if (strcmp(current->keys[i].name, line) == 0) {
-                    if (handle_key(&current->keys[i], &p[1]) < 0) {
-                        fclose(fp);
-                        return -1;
-                    }
-                    break;
-                }
-            }
-        } else {
-            fprintf(stderr, "malformed config line: %s\n", line);
-            fclose(fp);
-            return -1;
-        }
-    }
-
-    if (current && current->done)
-        current->done(data);
-
-    fclose(fp);
-
-    return 0;
-}
-
-char *
-config_file_path(const char *name)
-{
-    const char dotconf[] = "/.config/";
-    const char *config_dir;
-    const char *home_dir;
-    char *path;
-    size_t size;
-
-    config_dir = getenv("XDG_CONFIG_HOME");
-    if (!config_dir) {
-        home_dir = getenv("HOME");
-        if (!home_dir) {
-            fprintf(stderr, "HOME is not set, using cwd.\n");
-            return strdup(name);
-        }
-
-        size = strlen(home_dir) + sizeof dotconf + strlen(name);
-        path = malloc(size);
-        if (!path)
-            return NULL;
-
-        snprintf(path, size, "%s%s%s", home_dir, dotconf, name);
-        return path;
-    }
-
-    size = strlen(config_dir) + 1 + strlen(name) + 1;
-    path = malloc(size);
-    if (!path)
-        return NULL;
-
-    snprintf(path, size, "%s/%s", config_dir, name);
-    return path;
-}
diff --git a/src/config-parser.h b/src/config-parser.h
deleted file mode 100644 (file)
index 0f6ca84..0000000
+++ /dev/null
@@ -1,73 +0,0 @@
-/*
- * 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 */
-
index 1d020b5..b7d8882 100644 (file)
@@ -40,7 +40,7 @@
 #include <sys/types.h>
 
 #include <wayland-server.h>
-#include "compositor.h"
+#include <weston/compositor.h>
 #include "ico_ivi_common.h"
 #include "ico_ivi_shell.h"
 #include "ico_window_mgr.h"
index 39c84cb..c1917f7 100644 (file)
@@ -36,7 +36,7 @@
 #include <unistd.h>
 #include <dlfcn.h>
 
-#include "compositor.h"
+#include <weston/compositor.h>
 #include "ico_ivi_common.h"
 
 /* IVI Plugin Common Table                  */
index 34c09da..e245134 100644 (file)
@@ -42,7 +42,7 @@
 #include <time.h>
 
 #include <wayland-server.h>
-#include "compositor.h"
+#include <weston/compositor.h>
 #include "ico_ivi_common.h"
 #include "ico_ivi_shell.h"
 #include "ico_ivi_shell-server-protocol.h"
index 18b476f..dbba8f4 100644 (file)
@@ -40,7 +40,7 @@
 #include <sys/time.h>
 #include <time.h>
 
-#include "compositor.h"
+#include <weston/compositor.h>
 #include "ico_ivi_common.h"
 
 /* This function is called from the main body of Weston and initializes this module.*/
index 963e7c9..4a2b155 100644 (file)
@@ -46,7 +46,7 @@
 #include <aul/aul.h>
 #include <bundle.h>
 
-#include "compositor.h"
+#include <weston/compositor.h>
 #include "ico_ivi_common.h"
 #include "ico_ivi_shell.h"
 #include "ico_window_mgr.h"
diff --git a/src/matrix.h b/src/matrix.h
deleted file mode 100644 (file)
index 45d346f..0000000
+++ /dev/null
@@ -1,64 +0,0 @@
-/*
- * 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
-
-struct weston_matrix {
-    float d[16];
-};
-
-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_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 */