summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOssama Othman <ossama.othman@intel.com>2013-04-30 14:37:25 -0700
committerOssama Othman <ossama.othman@intel.com>2013-04-30 14:37:25 -0700
commit207a8c6b827716bf9138e6761c3f81a558837fbf (patch)
tree812546926361ad10d34c276f31949ea291163130
parent23fb3f796ce8373a34c5aef901267bad18956547 (diff)
downloadico-uxf-weston-plugin-207a8c6b827716bf9138e6761c3f81a558837fbf.tar.gz
ico-uxf-weston-plugin-207a8c6b827716bf9138e6761c3f81a558837fbf.tar.bz2
ico-uxf-weston-plugin-207a8c6b827716bf9138e6761c3f81a558837fbf.zip
Port ico-uxf-weston-plugin to use Weston 1.0.6 plugin API.
Change-Id: I7206280c389318a4b6492e36871c11bc2739f0ed Signed-off-by: Ossama Othman <ossama.othman@intel.com>
-rw-r--r--configure.ac12
-rw-r--r--packaging/ico-uxf-weston-plugin.spec10
l---------shared1
-rw-r--r--src/Makefile.am43
-rw-r--r--src/compositor.h841
-rw-r--r--src/config-parser.c187
-rw-r--r--src/config-parser.h73
-rw-r--r--src/ico_input_mgr.c2
-rw-r--r--src/ico_ivi_common.c2
-rw-r--r--src/ico_ivi_shell.c2
-rw-r--r--src/ico_plugin_loader.c2
-rw-r--r--src/ico_window_mgr.c2
-rw-r--r--src/matrix.h64
13 files changed, 29 insertions, 1212 deletions
diff --git a/configure.ac b/configure.ac
index f50ba04..0cf5a51 100644
--- a/configure.ac
+++ b/configure.ac
@@ -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 \
diff --git a/packaging/ico-uxf-weston-plugin.spec b/packaging/ico-uxf-weston-plugin.spec
index 05db689..1ea0821 100644
--- a/packaging/ico-uxf-weston-plugin.spec
+++ b/packaging/ico-uxf-weston-plugin.spec
@@ -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
index e831038..0000000
--- a/shared
+++ /dev/null
@@ -1 +0,0 @@
-src \ No newline at end of file
diff --git a/src/Makefile.am b/src/Makefile.am
index 9401246..4031d79 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -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
index d2ae587..0000000
--- a/src/compositor.h
+++ /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
index 95c6cf8..0000000
--- a/src/config-parser.c
+++ /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
index 0f6ca84..0000000
--- a/src/config-parser.h
+++ /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 */
-
diff --git a/src/ico_input_mgr.c b/src/ico_input_mgr.c
index 1d020b5..b7d8882 100644
--- a/src/ico_input_mgr.c
+++ b/src/ico_input_mgr.c
@@ -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"
diff --git a/src/ico_ivi_common.c b/src/ico_ivi_common.c
index 39c84cb..c1917f7 100644
--- a/src/ico_ivi_common.c
+++ b/src/ico_ivi_common.c
@@ -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 */
diff --git a/src/ico_ivi_shell.c b/src/ico_ivi_shell.c
index 34c09da..e245134 100644
--- a/src/ico_ivi_shell.c
+++ b/src/ico_ivi_shell.c
@@ -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"
diff --git a/src/ico_plugin_loader.c b/src/ico_plugin_loader.c
index 18b476f..dbba8f4 100644
--- a/src/ico_plugin_loader.c
+++ b/src/ico_plugin_loader.c
@@ -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.*/
diff --git a/src/ico_window_mgr.c b/src/ico_window_mgr.c
index 963e7c9..4a2b155 100644
--- a/src/ico_window_mgr.c
+++ b/src/ico_window_mgr.c
@@ -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
index 45d346f..0000000
--- a/src/matrix.h
+++ /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 */