|
|
|
ACLOCAL_AMFLAGS = -I m4
|
|
|
|
|
|
|
|
bin_PROGRAMS =
|
|
|
|
noinst_PROGRAMS =
|
|
|
|
libexec_PROGRAMS =
|
|
|
|
moduledir = $(libdir)/weston
|
|
|
|
module_LTLIBRARIES =
|
|
|
|
noinst_LTLIBRARIES =
|
|
|
|
BUILT_SOURCES =
|
|
|
|
|
|
|
|
AM_DISTCHECK_CONFIGURE_FLAGS = --disable-setuid-install
|
|
|
|
|
|
|
|
EXTRA_DIST = weston.ini.in ivi-shell/weston.ini.in
|
|
|
|
|
|
|
|
weston.ini : $(srcdir)/weston.ini.in
|
|
|
|
$(AM_V_GEN)$(SED) \
|
|
|
|
-e 's|@bindir[@]|$(bindir)|g' \
|
|
|
|
-e 's|@abs_top_builddir[@]|$(abs_top_builddir)|g' \
|
|
|
|
-e 's|@libexecdir[@]|$(libexecdir)|g' \
|
|
|
|
$< > $@
|
|
|
|
|
|
|
|
ivi-shell/weston.ini : $(srcdir)/ivi-shell/weston.ini.in
|
|
|
|
$(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(SED) \
|
|
|
|
-e 's|@bindir[@]|$(bindir)|g' \
|
|
|
|
-e 's|@abs_top_builddir[@]|$(abs_top_builddir)|g' \
|
|
|
|
-e 's|@abs_top_srcdir[@]|$(abs_top_srcdir)|g' \
|
|
|
|
-e 's|@libexecdir[@]|$(libexecdir)|g' \
|
|
|
|
-e 's|@plugin_prefix[@]||g' \
|
|
|
|
$< > $@
|
|
|
|
|
|
|
|
tests/weston-ivi.ini : $(srcdir)/ivi-shell/weston.ini.in
|
|
|
|
$(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(SED) \
|
|
|
|
-e 's|@bindir[@]|$(bindir)|g' \
|
|
|
|
-e 's|@abs_top_builddir[@]|$(abs_top_builddir)|g' \
|
|
|
|
-e 's|@abs_top_srcdir[@]|$(abs_top_srcdir)|g' \
|
|
|
|
-e 's|@libexecdir[@]|$(abs_builddir)|g' \
|
|
|
|
-e 's|@plugin_prefix[@]|$(abs_top_builddir)/.libs/|g' \
|
|
|
|
$< > $@
|
|
|
|
|
|
|
|
all-local : weston.ini ivi-shell/weston.ini
|
|
|
|
|
|
|
|
AM_CFLAGS = $(GCC_CFLAGS)
|
|
|
|
|
|
|
|
AM_CPPFLAGS = \
|
|
|
|
-I$(top_srcdir)/src \
|
|
|
|
-I$(top_builddir)/src \
|
|
|
|
-I$(top_builddir)/clients \
|
|
|
|
-I$(top_builddir)/tests \
|
|
|
|
-I$(top_srcdir)/shared \
|
|
|
|
-I$(top_builddir)/protocol \
|
|
|
|
-DDATADIR='"$(datadir)"' \
|
|
|
|
-DMODULEDIR='"$(moduledir)"' \
|
|
|
|
-DLIBEXECDIR='"$(libexecdir)"' \
|
|
|
|
-DBINDIR='"$(bindir)"'
|
|
|
|
|
|
|
|
CLEANFILES = weston.ini \
|
|
|
|
ivi-shell/weston.ini \
|
|
|
|
tests/weston-ivi.ini \
|
|
|
|
internal-screenshot-00.png \
|
|
|
|
$(BUILT_SOURCES)
|
|
|
|
|
|
|
|
bin_PROGRAMS += weston
|
|
|
|
|
|
|
|
weston_LDFLAGS = -export-dynamic
|
|
|
|
weston_CPPFLAGS = $(AM_CPPFLAGS) -DIN_WESTON
|
|
|
|
weston_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS) $(LIBUNWIND_CFLAGS)
|
|
|
|
weston_LDADD = $(COMPOSITOR_LIBS) $(LIBUNWIND_LIBS) \
|
|
|
|
$(DLOPEN_LIBS) -lm $(CLOCK_GETTIME_LIBS) libshared.la
|
|
|
|
|
|
|
|
weston_SOURCES = \
|
|
|
|
src/git-version.h \
|
|
|
|
src/log.c \
|
|
|
|
src/compositor.c \
|
|
|
|
src/compositor.h \
|
|
|
|
src/compositor-drm.h \
|
|
|
|
src/compositor-fbdev.h \
|
|
|
|
src/compositor-headless.h \
|
|
|
|
src/compositor-rdp.h \
|
|
|
|
src/compositor-wayland.h \
|
|
|
|
src/compositor-x11.h \
|
|
|
|
src/input.c \
|
|
|
|
src/data-device.c \
|
|
|
|
src/screenshooter.c \
|
|
|
|
src/clipboard.c \
|
|
|
|
src/zoom.c \
|
|
|
|
src/text-backend.c \
|
|
|
|
src/bindings.c \
|
|
|
|
src/animation.c \
|
|
|
|
src/noop-renderer.c \
|
|
|
|
src/pixman-renderer.c \
|
|
|
|
src/pixman-renderer.h \
|
compositor: Implement JSON-timeline logging
Logging is activated and deactivated with the debug key binding 't'.
When activated, it creates a new log file, where it records the events.
The log file contains events and detailed object information entries in
JSON format, and is meant to be parsed in sequence from beginning to the
end.
The emitted events are mostly related to the output repaint cycle, like
when repaint begins, is submitted to GPU, and when it completes on a
vblank. This is recorded per-output. Also some per-surface events are
recorded, including when surface damage is flushed.
To reduce the log size, events refer to objects like outputs and
surfaces by id numbers. Detailed object information is emitted only as
needed: on the first object occurrence, and afterwards only if
weston_timeline_object::force_refresh asks for it.
The detailed information for surfaces includes the string returned by
weston_surface::get_label. Therefore it is important to set
weston_timeline_object::force_refresh = 1 whenever the string would
change, so that the new details get recorded.
A rudimentary parser and SVG generator can be found at:
https://github.com/ppaalanen/wesgr
The timeline logs can answer questions including:
- How does the compositor repaint cycle work timing-wise?
- When was the vblank deadline missed?
- What is the latency from surface commit to showing the new content on
screen?
- How long does it take to process the scenegraph?
v2: weston_surface::get_description renamed to get_label.
v3: reafctor a bit into fprint_quoted_string().
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
src/timeline.c \
|
|
|
|
src/timeline.h \
|
|
|
|
src/timeline-object.h \
|
|
|
|
src/main.c \
|
|
|
|
src/linux-dmabuf.c \
|
|
|
|
src/linux-dmabuf.h \
|
|
|
|
shared/helpers.h \
|
|
|
|
shared/matrix.c \
|
|
|
|
shared/matrix.h \
|
|
|
|
shared/timespec-util.h \
|
|
|
|
shared/zalloc.h \
|
|
|
|
shared/platform.h \
|
|
|
|
src/weston-egl-ext.h
|
|
|
|
|
|
|
|
if SYSTEMD_NOTIFY_SUPPORT
|
|
|
|
module_LTLIBRARIES += systemd-notify.la
|
|
|
|
systemd_notify_la_LDFLAGS = -module -avoid-version
|
|
|
|
systemd_notify_la_LIBADD = $(SYSTEMD_DAEMON_LIBS)
|
|
|
|
systemd_notify_la_CFLAGS = \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(SYSTEMD_DAEMON_CFLAGS) \
|
|
|
|
$(PIXMAN_CFLAGS) \
|
|
|
|
$(AM_CFLAGS)
|
|
|
|
systemd_notify_la_SOURCES = \
|
|
|
|
src/systemd-notify.c \
|
|
|
|
shared/helpers.h \
|
|
|
|
shared/zalloc.h \
|
|
|
|
src/compositor.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
nodist_weston_SOURCES = \
|
|
|
|
protocol/weston-screenshooter-protocol.c \
|
|
|
|
protocol/weston-screenshooter-server-protocol.h \
|
|
|
|
protocol/text-cursor-position-protocol.c \
|
|
|
|
protocol/text-cursor-position-server-protocol.h \
|
|
|
|
protocol/text-input-unstable-v1-protocol.c \
|
|
|
|
protocol/text-input-unstable-v1-server-protocol.h \
|
|
|
|
protocol/input-method-unstable-v1-protocol.c \
|
|
|
|
protocol/input-method-unstable-v1-server-protocol.h \
|
|
|
|
protocol/presentation-time-protocol.c \
|
|
|
|
protocol/presentation-time-server-protocol.h \
|
|
|
|
protocol/scaler-protocol.c \
|
|
|
|
protocol/scaler-server-protocol.h \
|
|
|
|
protocol/linux-dmabuf-unstable-v1-protocol.c \
|
|
|
|
protocol/linux-dmabuf-unstable-v1-server-protocol.h
|
|
|
|
|
|
|
|
BUILT_SOURCES += $(nodist_weston_SOURCES)
|
|
|
|
|
|
|
|
# Track this dependency explicitly instead of using BUILT_SOURCES. We
|
|
|
|
# add BUILT_SOURCES to CLEANFILES, but we want to keep git-version.h
|
|
|
|
# in case we're building from tarballs.
|
|
|
|
|
|
|
|
src/compositor.c : $(top_builddir)/src/git-version.h
|
|
|
|
|
|
|
|
noinst_LTLIBRARIES += \
|
|
|
|
libsession-helper.la
|
|
|
|
|
|
|
|
libsession_helper_la_SOURCES = \
|
|
|
|
src/launcher-util.c \
|
|
|
|
src/launcher-util.h \
|
|
|
|
src/launcher-impl.h \
|
|
|
|
src/weston-launch.h \
|
|
|
|
src/launcher-weston-launch.c \
|
|
|
|
src/launcher-direct.c
|
|
|
|
libsession_helper_la_CFLAGS = $(AM_CFLAGS) $(LIBDRM_CFLAGS) $(PIXMAN_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
libsession_helper_la_LIBADD = $(LIBDRM_LIBS)
|
|
|
|
|
|
|
|
if ENABLE_DBUS
|
|
|
|
if HAVE_SYSTEMD_LOGIN
|
|
|
|
libsession_helper_la_SOURCES += \
|
|
|
|
src/dbus.h \
|
|
|
|
src/dbus.c \
|
|
|
|
src/launcher-logind.c
|
|
|
|
libsession_helper_la_CFLAGS += $(SYSTEMD_LOGIN_CFLAGS) $(DBUS_CFLAGS)
|
|
|
|
libsession_helper_la_LIBADD += $(SYSTEMD_LOGIN_LIBS) $(DBUS_LIBS)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
if HAVE_GIT_REPO
|
|
|
|
src/git-version.h : $(top_srcdir)/.git/logs/HEAD
|
|
|
|
$(AM_V_GEN)echo "#define BUILD_ID \"$(shell git --git-dir=$(top_srcdir)/.git describe --always --dirty) $(shell git --git-dir=$(top_srcdir)/.git log -1 --format='%s (%ci)')\"" > $@
|
|
|
|
else
|
|
|
|
src/git-version.h :
|
|
|
|
$(AM_V_GEN)echo "#define BUILD_ID \"unknown (not built from git or tarball)\"" > $@
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
.FORCE :
|
|
|
|
|
|
|
|
if BUILD_WESTON_LAUNCH
|
|
|
|
bin_PROGRAMS += weston-launch
|
|
|
|
weston_launch_SOURCES = src/weston-launch.c src/weston-launch.h
|
|
|
|
weston_launch_CPPFLAGS = -DBINDIR='"$(bindir)"'
|
|
|
|
weston_launch_CFLAGS= \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
$(PAM_CFLAGS) \
|
|
|
|
$(SYSTEMD_LOGIN_CFLAGS) \
|
|
|
|
$(LIBDRM_CFLAGS)
|
|
|
|
weston_launch_LDADD = $(PAM_LIBS) $(SYSTEMD_LOGIN_LIBS) $(LIBDRM_LIBS)
|
|
|
|
|
|
|
|
if ENABLE_SETUID_INSTALL
|
|
|
|
install-exec-hook:
|
|
|
|
can_suid_files=no; \
|
|
|
|
chown root $(DESTDIR)$(bindir)/weston-launch \
|
|
|
|
&& chmod u+s $(DESTDIR)$(bindir)/weston-launch \
|
|
|
|
&& can_suid_files=yes;\
|
|
|
|
if test $$can_suid_files = no; then \
|
|
|
|
echo 'Error: unable to unable to change ownership/setuid on weston-launch.'; \
|
|
|
|
echo 'To skip this step, re-run ./configure using --disable-setuid-install'; \
|
|
|
|
false; \
|
|
|
|
fi
|
|
|
|
endif
|
|
|
|
|
|
|
|
endif # BUILD_WESTON_LAUNCH
|
|
|
|
|
|
|
|
pkgconfigdir = $(libdir)/pkgconfig
|
|
|
|
pkgconfig_DATA = src/weston.pc
|
|
|
|
|
|
|
|
wayland_sessiondir = $(datadir)/wayland-sessions
|
|
|
|
dist_wayland_session_DATA = src/weston.desktop
|
|
|
|
|
|
|
|
westonincludedir = $(includedir)/weston
|
|
|
|
westoninclude_HEADERS = \
|
|
|
|
src/version.h \
|
|
|
|
src/compositor.h \
|
|
|
|
src/compositor-drm.h \
|
|
|
|
src/compositor-fbdev.h \
|
|
|
|
src/compositor-headless.h \
|
|
|
|
src/compositor-rdp.h \
|
|
|
|
src/compositor-wayland.h \
|
|
|
|
src/compositor-x11.h \
|
compositor: Implement JSON-timeline logging
Logging is activated and deactivated with the debug key binding 't'.
When activated, it creates a new log file, where it records the events.
The log file contains events and detailed object information entries in
JSON format, and is meant to be parsed in sequence from beginning to the
end.
The emitted events are mostly related to the output repaint cycle, like
when repaint begins, is submitted to GPU, and when it completes on a
vblank. This is recorded per-output. Also some per-surface events are
recorded, including when surface damage is flushed.
To reduce the log size, events refer to objects like outputs and
surfaces by id numbers. Detailed object information is emitted only as
needed: on the first object occurrence, and afterwards only if
weston_timeline_object::force_refresh asks for it.
The detailed information for surfaces includes the string returned by
weston_surface::get_label. Therefore it is important to set
weston_timeline_object::force_refresh = 1 whenever the string would
change, so that the new details get recorded.
A rudimentary parser and SVG generator can be found at:
https://github.com/ppaalanen/wesgr
The timeline logs can answer questions including:
- How does the compositor repaint cycle work timing-wise?
- When was the vblank deadline missed?
- What is the latency from surface commit to showing the new content on
screen?
- How long does it take to process the scenegraph?
v2: weston_surface::get_description renamed to get_label.
v3: reafctor a bit into fprint_quoted_string().
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
src/timeline-object.h \
|
|
|
|
shared/matrix.h \
|
|
|
|
shared/config-parser.h \
|
|
|
|
shared/zalloc.h \
|
|
|
|
shared/platform.h
|
|
|
|
|
|
|
|
if ENABLE_IVI_SHELL
|
|
|
|
westoninclude_HEADERS += \
|
|
|
|
ivi-shell/ivi-layout-export.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_EGL
|
|
|
|
module_LTLIBRARIES += gl-renderer.la
|
|
|
|
gl_renderer_la_LDFLAGS = -module -avoid-version
|
|
|
|
gl_renderer_la_LIBADD = $(COMPOSITOR_LIBS) $(EGL_LIBS)
|
|
|
|
gl_renderer_la_CFLAGS = \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(EGL_CFLAGS) \
|
|
|
|
$(GL_RENDERER_CFLAGS) \
|
|
|
|
$(AM_CFLAGS)
|
|
|
|
gl_renderer_la_SOURCES = \
|
|
|
|
src/gl-renderer.h \
|
|
|
|
src/gl-renderer.c \
|
|
|
|
src/vertex-clipping.c \
|
|
|
|
src/vertex-clipping.h \
|
|
|
|
shared/helpers.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_X11_COMPOSITOR
|
|
|
|
module_LTLIBRARIES += x11-backend.la
|
|
|
|
x11_backend_la_LDFLAGS = -module -avoid-version
|
|
|
|
x11_backend_la_LIBADD = $(COMPOSITOR_LIBS) $(X11_COMPOSITOR_LIBS) \
|
|
|
|
libshared-cairo.la
|
|
|
|
x11_backend_la_CFLAGS = \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(EGL_CFLAGS) \
|
|
|
|
$(PIXMAN_CFLAGS) \
|
|
|
|
$(CAIRO_CFLAGS) \
|
|
|
|
$(X11_COMPOSITOR_CFLAGS) \
|
|
|
|
$(AM_CFLAGS)
|
|
|
|
x11_backend_la_SOURCES = \
|
|
|
|
src/compositor-x11.c \
|
|
|
|
src/compositor-x11.h \
|
|
|
|
shared/helpers.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
INPUT_BACKEND_LIBS = $(LIBINPUT_BACKEND_LIBS)
|
|
|
|
INPUT_BACKEND_SOURCES = \
|
|
|
|
src/libinput-seat.c \
|
|
|
|
src/libinput-seat.h \
|
|
|
|
src/libinput-device.c \
|
|
|
|
src/libinput-device.h \
|
|
|
|
shared/helpers.h
|
|
|
|
|
|
|
|
if ENABLE_DRM_COMPOSITOR
|
|
|
|
module_LTLIBRARIES += drm-backend.la
|
|
|
|
drm_backend_la_LDFLAGS = -module -avoid-version
|
|
|
|
drm_backend_la_LIBADD = \
|
|
|
|
$(COMPOSITOR_LIBS) \
|
|
|
|
$(DRM_COMPOSITOR_LIBS) \
|
|
|
|
$(INPUT_BACKEND_LIBS) \
|
|
|
|
libshared.la \
|
|
|
|
$(CLOCK_GETTIME_LIBS) \
|
|
|
|
libsession-helper.la
|
|
|
|
drm_backend_la_CFLAGS = \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(EGL_CFLAGS) \
|
|
|
|
$(DRM_COMPOSITOR_CFLAGS) \
|
|
|
|
$(AM_CFLAGS)
|
|
|
|
drm_backend_la_SOURCES = \
|
|
|
|
src/compositor-drm.c \
|
|
|
|
src/compositor-drm.h \
|
|
|
|
$(INPUT_BACKEND_SOURCES) \
|
|
|
|
shared/helpers.h \
|
compositor-drm: Allow instant start of repaint loop. (v4)
drm_output_start_repaint_loop() incurred a delay of
one refresh cycle by using a no-op page-flip to get
an accurate vblank timestamp as reference. This causes
unwanted lag whenever Weston exited its repaint loop, e.g.,
whenever an application wants to repaint with less than
full video refresh rate but still minimum lag.
Try to use the drmWaitVblank ioctl to get a proper
timestamp instantaneously without lag. If that does
not work, fall back to the old method of idle page-flip.
This optimization will work on any drm/kms driver
which supports high precision vblank timestamping.
As of Linux 4.0 these would be intel, radeon and
nouveau on all their supported gpu's.
On kms drivers without instant high precision timestamping
support, the kernel is supposed to return a timestamp
of zero when calling drmWaitVblank() to query the current
vblank count and time iff vblank irqs are currently
disabled, because the only way to get a valid timestamp
on such kms drivers is to enable vblank interrupts and
then wait a bit for the next vblank irq to take a new valid
timestamp. The caller is supposed to poll until at next
vblank irq it gets a valid non-zero timestamp if it needs
a timestamp.
This zero-timestamp signalling works up to Linux 3.17, but
got broken due to a regression in Linux 3.18 and later. On
Linux 3.18+ with kms drivers that don't have high precision
timestamping, the kernel erroneously returns a stale timestamp
from an earlier vblank, ie. the vblank count and timestamp are
mismatched. A patch is under way to fix this, but to deal with
broken kernels, we also check non-zero timestamps if they are
more than one refresh duration in the past, as this indicates
a stale/invalid timestamp, so we need to take the page-flip
fallback for restarting the repaint loop.
v2: Implement review suggestions by Pekka Paalanen, especially
extend the commit message to describe when and why the
instant restart won't work due to missing Linux kernel
functionality or a Linux kernel regression.
Signed-off-by: Mario Kleiner <mario.kleiner.de@gmail.com>
Reviewed-by: Daniel Stone <daniels@collabora.com>
v3: Fix timespec_to_nsec() which was computing picoseconds,
use the new timespec-util.h helpers.
v4: Rebased to master, split long lines.
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
shared/timespec-util.h \
|
|
|
|
src/libbacklight.c \
|
|
|
|
src/libbacklight.h
|
|
|
|
|
|
|
|
if ENABLE_VAAPI_RECORDER
|
|
|
|
drm_backend_la_SOURCES += src/vaapi-recorder.c src/vaapi-recorder.h
|
|
|
|
drm_backend_la_LIBADD += $(LIBVA_LIBS)
|
|
|
|
drm_backend_la_CFLAGS += $(LIBVA_CFLAGS)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_WAYLAND_COMPOSITOR
|
|
|
|
module_LTLIBRARIES += wayland-backend.la
|
|
|
|
wayland_backend_la_LDFLAGS = -module -avoid-version
|
|
|
|
wayland_backend_la_LIBADD = \
|
|
|
|
$(COMPOSITOR_LIBS) \
|
|
|
|
$(WAYLAND_COMPOSITOR_LIBS) \
|
|
|
|
libshared-cairo.la
|
|
|
|
wayland_backend_la_CFLAGS = \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(EGL_CFLAGS) \
|
|
|
|
$(PIXMAN_CFLAGS) \
|
|
|
|
$(CAIRO_CFLAGS) \
|
|
|
|
$(WAYLAND_COMPOSITOR_CFLAGS) \
|
|
|
|
$(AM_CFLAGS)
|
|
|
|
wayland_backend_la_SOURCES = \
|
|
|
|
src/compositor-wayland.c \
|
|
|
|
src/compositor-wayland.h \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_wayland_backend_la_SOURCES = \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-client-protocol.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_RPI_COMPOSITOR
|
|
|
|
if INSTALL_RPI_COMPOSITOR
|
|
|
|
module_LTLIBRARIES += rpi-backend.la
|
|
|
|
else
|
|
|
|
noinst_LTLIBRARIES += rpi-backend.la
|
|
|
|
endif
|
|
|
|
|
|
|
|
rpi_backend_la_LDFLAGS = -module -avoid-version
|
|
|
|
rpi_backend_la_LIBADD = $(COMPOSITOR_LIBS) \
|
|
|
|
$(RPI_COMPOSITOR_LIBS) \
|
|
|
|
$(RPI_BCM_HOST_LIBS) \
|
|
|
|
$(INPUT_BACKEND_LIBS) \
|
|
|
|
libsession-helper.la \
|
|
|
|
libshared.la
|
|
|
|
rpi_backend_la_CFLAGS = \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(RPI_COMPOSITOR_CFLAGS) \
|
|
|
|
$(RPI_BCM_HOST_CFLAGS)
|
|
|
|
rpi_backend_la_SOURCES = \
|
|
|
|
src/compositor-rpi.c \
|
|
|
|
src/rpi-renderer.c \
|
|
|
|
src/rpi-renderer.h \
|
|
|
|
src/rpi-bcm-stubs.h \
|
|
|
|
shared/helpers.h \
|
|
|
|
$(INPUT_BACKEND_SOURCES)
|
|
|
|
|
|
|
|
if ENABLE_EGL
|
|
|
|
rpi_backend_la_LIBADD += $(EGL_LIBS)
|
|
|
|
rpi_backend_la_CFLAGS += $(EGL_CFLAGS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_HEADLESS_COMPOSITOR
|
|
|
|
module_LTLIBRARIES += headless-backend.la
|
|
|
|
headless_backend_la_LDFLAGS = -module -avoid-version
|
|
|
|
headless_backend_la_LIBADD = $(COMPOSITOR_LIBS) libshared.la
|
|
|
|
headless_backend_la_CFLAGS = $(COMPOSITOR_CFLAGS) $(AM_CFLAGS)
|
|
|
|
headless_backend_la_SOURCES = \
|
|
|
|
src/compositor-headless.c \
|
|
|
|
src/compositor-headless.h \
|
|
|
|
shared/helpers.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_FBDEV_COMPOSITOR
|
|
|
|
module_LTLIBRARIES += fbdev-backend.la
|
|
|
|
fbdev_backend_la_LDFLAGS = -module -avoid-version
|
|
|
|
fbdev_backend_la_LIBADD = \
|
|
|
|
$(COMPOSITOR_LIBS) \
|
|
|
|
$(FBDEV_COMPOSITOR_LIBS) \
|
|
|
|
$(INPUT_BACKEND_LIBS) \
|
|
|
|
libsession-helper.la \
|
|
|
|
libshared.la
|
|
|
|
fbdev_backend_la_CFLAGS = \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(EGL_CFLAGS) \
|
|
|
|
$(FBDEV_COMPOSITOR_CFLAGS) \
|
|
|
|
$(PIXMAN_CFLAGS) \
|
|
|
|
$(AM_CFLAGS)
|
|
|
|
fbdev_backend_la_SOURCES = \
|
|
|
|
src/compositor-fbdev.c \
|
|
|
|
src/compositor-fbdev.h \
|
|
|
|
shared/helpers.h \
|
|
|
|
$(INPUT_BACKEND_SOURCES)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_RDP_COMPOSITOR
|
|
|
|
module_LTLIBRARIES += rdp-backend.la
|
|
|
|
rdp_backend_la_LDFLAGS = -module -avoid-version
|
|
|
|
rdp_backend_la_LIBADD = $(COMPOSITOR_LIBS) \
|
|
|
|
$(RDP_COMPOSITOR_LIBS) \
|
|
|
|
libshared.la
|
|
|
|
rdp_backend_la_CFLAGS = \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(RDP_COMPOSITOR_CFLAGS) \
|
|
|
|
$(AM_CFLAGS)
|
|
|
|
rdp_backend_la_SOURCES = \
|
|
|
|
src/compositor-rdp.c \
|
|
|
|
src/compositor-rdp.h \
|
|
|
|
shared/helpers.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
if HAVE_LCMS
|
|
|
|
module_LTLIBRARIES += cms-static.la
|
|
|
|
cms_static_la_LDFLAGS = -module -avoid-version
|
|
|
|
cms_static_la_LIBADD = $(COMPOSITOR_LIBS) $(LCMS_LIBS) libshared.la
|
|
|
|
cms_static_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS) $(LCMS_CFLAGS)
|
|
|
|
cms_static_la_SOURCES = \
|
|
|
|
src/cms-static.c \
|
|
|
|
src/cms-helper.c \
|
|
|
|
src/cms-helper.h \
|
|
|
|
shared/helpers.h
|
|
|
|
if ENABLE_COLORD
|
|
|
|
module_LTLIBRARIES += cms-colord.la
|
|
|
|
cms_colord_la_LDFLAGS = -module -avoid-version
|
|
|
|
cms_colord_la_LIBADD = $(COMPOSITOR_LIBS) $(COLORD_LIBS)
|
|
|
|
cms_colord_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS) $(COLORD_CFLAGS)
|
|
|
|
cms_colord_la_SOURCES = \
|
|
|
|
src/cms-colord.c \
|
|
|
|
src/cms-helper.c \
|
|
|
|
src/cms-helper.h \
|
|
|
|
shared/helpers.h
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
noinst_PROGRAMS += spring-tool
|
|
|
|
spring_tool_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
spring_tool_LDADD = $(COMPOSITOR_LIBS) -lm
|
|
|
|
spring_tool_SOURCES = \
|
|
|
|
src/spring-tool.c \
|
|
|
|
src/animation.c \
|
|
|
|
shared/matrix.c \
|
|
|
|
shared/matrix.h \
|
|
|
|
src/compositor.h
|
|
|
|
|
|
|
|
if BUILD_CLIENTS
|
|
|
|
|
|
|
|
bin_PROGRAMS += weston-terminal weston-info
|
|
|
|
|
|
|
|
libexec_PROGRAMS += \
|
|
|
|
weston-desktop-shell \
|
|
|
|
weston-screenshooter \
|
|
|
|
weston-keyboard \
|
|
|
|
weston-simple-im
|
|
|
|
|
clients: a reference implementation of UI client how to use ivi-hmi-controller.
- introduces ivi-shell-user-interface.c
This is launched from hmi-controller by launch_hmi_client_process and
invoke a
client process.
The basic flow is as followed,
1/ process invoked
2/ read configuration from weston.ini.
3/ draw png file to surface according to configuration of weston.ini
4/ all parts of UI are ready. request "UI_ready" to draw UI.
5/ Enter event loop
6/ If a surface receives touch/pointer event, followings are invoked
according
to type of event and surface
6-1/ If a surface to launch ivi_application receive touch up, it execs
ivi-application configured in weston.ini.
6-2/ If a surface to switch layout mode receive touch up, it sends a
request,
ivi_hmi_controller_switch_mode, to hmi-controller.
6-3/ If a surface to show workspace having launchers, it sends a
request,
ivi_hmi_controller_home, to hmi-controller.
6-4/ If touch down events happens in workspace,
ivi_hmi_controller_workspace_control is sent to slide workspace.
When control finished, event:
ivi_hmi_controller_workspace_end_control
is received.
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Acked-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
if ENABLE_IVI_SHELL
|
|
|
|
libexec_PROGRAMS += \
|
|
|
|
weston-ivi-shell-user-interface
|
|
|
|
endif
|
|
|
|
|
|
|
|
demo_clients = \
|
|
|
|
weston-flower \
|
|
|
|
weston-image \
|
|
|
|
weston-cliptest \
|
|
|
|
weston-dnd \
|
|
|
|
weston-smoke \
|
|
|
|
weston-resizor \
|
|
|
|
weston-eventdemo \
|
|
|
|
weston-clickdot \
|
|
|
|
weston-transformed \
|
|
|
|
weston-fullscreen \
|
|
|
|
weston-stacking \
|
|
|
|
weston-calibrator \
|
|
|
|
weston-scaler
|
|
|
|
|
|
|
|
if INSTALL_DEMO_CLIENTS
|
|
|
|
bin_PROGRAMS += $(demo_clients)
|
|
|
|
else
|
|
|
|
noinst_PROGRAMS += $(demo_clients)
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
if BUILD_SIMPLE_CLIENTS
|
|
|
|
demo_clients += \
|
|
|
|
weston-simple-shm \
|
|
|
|
weston-simple-damage \
|
|
|
|
weston-simple-touch \
|
|
|
|
weston-presentation-shm \
|
|
|
|
weston-multi-resource
|
|
|
|
|
|
|
|
weston_simple_shm_SOURCES = clients/simple-shm.c
|
|
|
|
nodist_weston_simple_shm_SOURCES = \
|
|
|
|
protocol/xdg-shell-unstable-v5-protocol.c \
|
|
|
|
protocol/xdg-shell-unstable-v5-client-protocol.h \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-client-protocol.h \
|
|
|
|
protocol/ivi-application-protocol.c \
|
|
|
|
protocol/ivi-application-client-protocol.h
|
|
|
|
weston_simple_shm_CFLAGS = $(AM_CFLAGS) $(SIMPLE_CLIENT_CFLAGS)
|
|
|
|
weston_simple_shm_LDADD = $(SIMPLE_CLIENT_LIBS) libshared.la
|
|
|
|
|
|
|
|
weston_simple_damage_SOURCES = clients/simple-damage.c
|
|
|
|
nodist_weston_simple_damage_SOURCES = \
|
|
|
|
protocol/scaler-protocol.c \
|
|
|
|
protocol/scaler-client-protocol.h \
|
|
|
|
protocol/xdg-shell-unstable-v5-protocol.c \
|
|
|
|
protocol/xdg-shell-unstable-v5-client-protocol.h \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-client-protocol.h
|
|
|
|
weston_simple_damage_CFLAGS = $(AM_CFLAGS) $(SIMPLE_CLIENT_CFLAGS)
|
|
|
|
weston_simple_damage_LDADD = $(SIMPLE_CLIENT_LIBS) libshared.la
|
|
|
|
|
|
|
|
weston_simple_touch_SOURCES = \
|
|
|
|
clients/simple-touch.c \
|
|
|
|
shared/helpers.h
|
|
|
|
weston_simple_touch_CFLAGS = $(AM_CFLAGS) $(SIMPLE_CLIENT_CFLAGS)
|
|
|
|
weston_simple_touch_LDADD = $(SIMPLE_CLIENT_LIBS) libshared.la
|
|
|
|
|
|
|
|
weston_presentation_shm_SOURCES = \
|
|
|
|
clients/presentation-shm.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_weston_presentation_shm_SOURCES = \
|
|
|
|
protocol/presentation-time-protocol.c \
|
|
|
|
protocol/presentation-time-client-protocol.h
|
|
|
|
weston_presentation_shm_CFLAGS = $(AM_CFLAGS) $(SIMPLE_CLIENT_CFLAGS)
|
|
|
|
weston_presentation_shm_LDADD = $(SIMPLE_CLIENT_LIBS) libshared.la -lm $(CLOCK_GETTIME_LIBS)
|
|
|
|
|
|
|
|
weston_multi_resource_SOURCES = clients/multi-resource.c
|
|
|
|
weston_multi_resource_CFLAGS = $(AM_CFLAGS) $(SIMPLE_CLIENT_CFLAGS)
|
|
|
|
weston_multi_resource_LDADD = $(SIMPLE_CLIENT_LIBS) libshared.la $(CLOCK_GETTIME_LIBS) -lm
|
|
|
|
endif
|
|
|
|
|
|
|
|
if BUILD_SIMPLE_EGL_CLIENTS
|
|
|
|
demo_clients += weston-simple-egl
|
|
|
|
weston_simple_egl_SOURCES = clients/simple-egl.c
|
|
|
|
nodist_weston_simple_egl_SOURCES = \
|
|
|
|
protocol/xdg-shell-unstable-v5-protocol.c \
|
|
|
|
protocol/xdg-shell-unstable-v5-client-protocol.h \
|
|
|
|
protocol/ivi-application-protocol.c \
|
|
|
|
protocol/ivi-application-client-protocol.h
|
|
|
|
weston_simple_egl_CFLAGS = $(AM_CFLAGS) $(SIMPLE_EGL_CLIENT_CFLAGS)
|
|
|
|
weston_simple_egl_LDADD = $(SIMPLE_EGL_CLIENT_LIBS) -lm
|
|
|
|
endif
|
|
|
|
|
|
|
|
if BUILD_SIMPLE_DMABUF_INTEL_CLIENT
|
|
|
|
demo_clients += weston-simple-dmabuf-intel
|
|
|
|
weston_simple_dmabuf_intel_SOURCES = clients/simple-dmabuf-intel.c
|
|
|
|
nodist_weston_simple_dmabuf_intel_SOURCES = \
|
|
|
|
protocol/xdg-shell-unstable-v5-protocol.c \
|
|
|
|
protocol/xdg-shell-unstable-v5-client-protocol.h \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-client-protocol.h \
|
|
|
|
protocol/linux-dmabuf-unstable-v1-protocol.c \
|
|
|
|
protocol/linux-dmabuf-unstable-v1-client-protocol.h
|
|
|
|
weston_simple_dmabuf_intel_CFLAGS = $(AM_CFLAGS) $(SIMPLE_DMABUF_INTEL_CLIENT_CFLAGS)
|
|
|
|
weston_simple_dmabuf_intel_LDADD = $(SIMPLE_DMABUF_INTEL_CLIENT_LIBS) libshared.la
|
|
|
|
BUILT_SOURCES += protocol/linux-dmabuf-unstable-v1-client-protocol.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
if BUILD_SIMPLE_DMABUF_V4L_CLIENT
|
|
|
|
demo_clients += weston-simple-dmabuf-v4l
|
|
|
|
weston_simple_dmabuf_v4l_SOURCES = clients/simple-dmabuf-v4l.c
|
|
|
|
nodist_weston_simple_dmabuf_v4l_SOURCES = \
|
|
|
|
protocol/xdg-shell-unstable-v5-protocol.c \
|
|
|
|
protocol/xdg-shell-unstable-v5-client-protocol.h \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-client-protocol.h \
|
|
|
|
protocol/linux-dmabuf-unstable-v1-protocol.c \
|
|
|
|
protocol/linux-dmabuf-unstable-v1-client-protocol.h
|
|
|
|
weston_simple_dmabuf_v4l_CFLAGS = $(AM_CFLAGS) $(SIMPLE_DMABUF_V4L_CLIENT_CFLAGS)
|
|
|
|
weston_simple_dmabuf_v4l_LDADD = $(SIMPLE_DMABUF_V4L_CLIENT_LIBS) libshared.la
|
|
|
|
BUILT_SOURCES += protocol/linux-dmabuf-unstable-v1-client-protocol.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
noinst_LTLIBRARIES += libtoytoolkit.la
|
|
|
|
|
|
|
|
libtoytoolkit_la_SOURCES = \
|
|
|
|
clients/window.c \
|
|
|
|
clients/window.h \
|
|
|
|
shared/helpers.h
|
|
|
|
|
|
|
|
nodist_libtoytoolkit_la_SOURCES = \
|
|
|
|
protocol/text-cursor-position-protocol.c \
|
|
|
|
protocol/text-cursor-position-client-protocol.h \
|
|
|
|
protocol/scaler-protocol.c \
|
|
|
|
protocol/scaler-client-protocol.h \
|
|
|
|
protocol/xdg-shell-unstable-v5-protocol.c \
|
|
|
|
protocol/xdg-shell-unstable-v5-client-protocol.h \
|
|
|
|
protocol/ivi-application-protocol.c \
|
|
|
|
protocol/ivi-application-client-protocol.h
|
|
|
|
|
|
|
|
BUILT_SOURCES += $(nodist_libtoytoolkit_la_SOURCES)
|
|
|
|
|
|
|
|
|
|
|
|
libtoytoolkit_la_LIBADD = \
|
|
|
|
$(CLIENT_LIBS) \
|
|
|
|
$(CAIRO_EGL_LIBS) \
|
|
|
|
libshared-cairo.la $(CLOCK_GETTIME_LIBS) -lm
|
|
|
|
libtoytoolkit_la_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS) $(CAIRO_EGL_CFLAGS)
|
|
|
|
|
|
|
|
weston_flower_SOURCES = clients/flower.c
|
|
|
|
weston_flower_LDADD = libtoytoolkit.la
|
|
|
|
weston_flower_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_screenshooter_SOURCES = \
|
|
|
|
clients/screenshot.c
|
|
|
|
nodist_weston_screenshooter_SOURCES = \
|
|
|
|
protocol/weston-screenshooter-protocol.c \
|
|
|
|
protocol/weston-screenshooter-client-protocol.h
|
|
|
|
weston_screenshooter_LDADD = $(CLIENT_LIBS) libshared.la
|
|
|
|
weston_screenshooter_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_terminal_SOURCES = \
|
|
|
|
clients/terminal.c \
|
|
|
|
shared/helpers.h
|
|
|
|
weston_terminal_LDADD = libtoytoolkit.la -lutil
|
|
|
|
weston_terminal_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_image_SOURCES = clients/image.c
|
|
|
|
weston_image_LDADD = libtoytoolkit.la
|
|
|
|
weston_image_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_cliptest_SOURCES = \
|
|
|
|
clients/cliptest.c \
|
|
|
|
src/vertex-clipping.c \
|
|
|
|
src/vertex-clipping.h
|
|
|
|
weston_cliptest_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
weston_cliptest_LDADD = libtoytoolkit.la
|
|
|
|
|
|
|
|
weston_dnd_SOURCES = \
|
|
|
|
clients/dnd.c \
|
|
|
|
shared/helpers.h
|
|
|
|
weston_dnd_LDADD = libtoytoolkit.la
|
|
|
|
weston_dnd_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_smoke_SOURCES = clients/smoke.c
|
|
|
|
weston_smoke_LDADD = libtoytoolkit.la
|
|
|
|
weston_smoke_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_resizor_SOURCES = clients/resizor.c
|
|
|
|
weston_resizor_LDADD = libtoytoolkit.la
|
|
|
|
weston_resizor_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_scaler_SOURCES = clients/scaler.c
|
|
|
|
weston_scaler_LDADD = libtoytoolkit.la
|
|
|
|
weston_scaler_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
if HAVE_CAIRO_GLESV2
|
|
|
|
demo_clients += weston-nested weston-nested-client
|
|
|
|
|
|
|
|
weston_nested_SOURCES = \
|
|
|
|
clients/nested.c \
|
|
|
|
shared/helpers.h
|
|
|
|
weston_nested_LDADD = libtoytoolkit.la $(SERVER_LIBS)
|
|
|
|
weston_nested_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_nested_client_SOURCES = clients/nested-client.c
|
|
|
|
weston_nested_client_LDADD = $(SIMPLE_EGL_CLIENT_LIBS) -lm
|
|
|
|
weston_nested_client_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
weston_eventdemo_SOURCES = \
|
|
|
|
clients/eventdemo.c \
|
|
|
|
shared/helpers.h
|
|
|
|
weston_eventdemo_LDADD = libtoytoolkit.la
|
|
|
|
weston_eventdemo_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_clickdot_SOURCES = \
|
|
|
|
clients/clickdot.c \
|
|
|
|
shared/helpers.h
|
|
|
|
weston_clickdot_LDADD = libtoytoolkit.la
|
|
|
|
weston_clickdot_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_transformed_SOURCES = clients/transformed.c
|
|
|
|
weston_transformed_LDADD = libtoytoolkit.la
|
|
|
|
weston_transformed_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_fullscreen_SOURCES = clients/fullscreen.c
|
|
|
|
nodist_weston_fullscreen_SOURCES = \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-client-protocol.h
|
|
|
|
weston_fullscreen_LDADD = libtoytoolkit.la
|
|
|
|
weston_fullscreen_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_stacking_SOURCES = \
|
|
|
|
clients/stacking.c \
|
|
|
|
shared/helpers.h
|
|
|
|
weston_stacking_LDADD = libtoytoolkit.la
|
|
|
|
weston_stacking_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_calibrator_SOURCES = \
|
|
|
|
clients/calibrator.c \
|
|
|
|
shared/helpers.h \
|
|
|
|
shared/matrix.c \
|
|
|
|
shared/matrix.h
|
|
|
|
weston_calibrator_LDADD = libtoytoolkit.la
|
|
|
|
weston_calibrator_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
if BUILD_SUBSURFACES_CLIENT
|
|
|
|
demo_clients += weston-subsurfaces
|
|
|
|
weston_subsurfaces_SOURCES = \
|
|
|
|
clients/subsurfaces.c \
|
|
|
|
shared/helpers.h
|
|
|
|
weston_subsurfaces_CFLAGS = \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
$(SIMPLE_EGL_CLIENT_CFLAGS) \
|
|
|
|
$(CLIENT_CFLAGS)
|
|
|
|
weston_subsurfaces_LDADD = libtoytoolkit.la $(SIMPLE_EGL_CLIENT_LIBS) -lm
|
|
|
|
endif
|
|
|
|
|
|
|
|
if HAVE_PANGO
|
|
|
|
demo_clients += weston-editor
|
|
|
|
weston_editor_SOURCES = \
|
|
|
|
clients/editor.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_weston_editor_SOURCES = \
|
|
|
|
protocol/text-input-unstable-v1-protocol.c \
|
|
|
|
protocol/text-input-unstable-v1-client-protocol.h
|
|
|
|
weston_editor_LDADD = libtoytoolkit.la $(PANGO_LIBS)
|
|
|
|
weston_editor_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS) $(PANGO_CFLAGS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
weston_keyboard_SOURCES = clients/keyboard.c
|
|
|
|
nodist_weston_keyboard_SOURCES = \
|
|
|
|
protocol/weston-desktop-shell-client-protocol.h \
|
|
|
|
protocol/weston-desktop-shell-protocol.c \
|
|
|
|
protocol/input-method-unstable-v1-protocol.c \
|
|
|
|
protocol/input-method-unstable-v1-client-protocol.h
|
|
|
|
weston_keyboard_LDADD = libtoytoolkit.la
|
|
|
|
weston_keyboard_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_simple_im_SOURCES = clients/weston-simple-im.c
|
|
|
|
nodist_weston_simple_im_SOURCES = \
|
|
|
|
protocol/input-method-unstable-v1-protocol.c \
|
|
|
|
protocol/input-method-unstable-v1-client-protocol.h
|
|
|
|
weston_simple_im_LDADD = $(CLIENT_LIBS)
|
|
|
|
weston_simple_im_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_info_SOURCES = \
|
|
|
|
clients/weston-info.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_weston_info_SOURCES = \
|
|
|
|
protocol/presentation-time-protocol.c \
|
|
|
|
protocol/presentation-time-client-protocol.h
|
|
|
|
weston_info_LDADD = $(WESTON_INFO_LIBS) libshared.la
|
|
|
|
weston_info_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
|
|
|
weston_desktop_shell_SOURCES = \
|
|
|
|
clients/desktop-shell.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_weston_desktop_shell_SOURCES = \
|
|
|
|
protocol/weston-desktop-shell-client-protocol.h \
|
|
|
|
protocol/weston-desktop-shell-protocol.c
|
|
|
|
weston_desktop_shell_LDADD = libtoytoolkit.la
|
|
|
|
weston_desktop_shell_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
|
clients: a reference implementation of UI client how to use ivi-hmi-controller.
- introduces ivi-shell-user-interface.c
This is launched from hmi-controller by launch_hmi_client_process and
invoke a
client process.
The basic flow is as followed,
1/ process invoked
2/ read configuration from weston.ini.
3/ draw png file to surface according to configuration of weston.ini
4/ all parts of UI are ready. request "UI_ready" to draw UI.
5/ Enter event loop
6/ If a surface receives touch/pointer event, followings are invoked
according
to type of event and surface
6-1/ If a surface to launch ivi_application receive touch up, it execs
ivi-application configured in weston.ini.
6-2/ If a surface to switch layout mode receive touch up, it sends a
request,
ivi_hmi_controller_switch_mode, to hmi-controller.
6-3/ If a surface to show workspace having launchers, it sends a
request,
ivi_hmi_controller_home, to hmi-controller.
6-4/ If touch down events happens in workspace,
ivi_hmi_controller_workspace_control is sent to slide workspace.
When control finished, event:
ivi_hmi_controller_workspace_end_control
is received.
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Acked-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
if ENABLE_IVI_SHELL
|
|
|
|
weston_ivi_shell_user_interface_SOURCES = \
|
|
|
|
clients/ivi-shell-user-interface.c \
|
|
|
|
shared/helpers.h
|
clients: a reference implementation of UI client how to use ivi-hmi-controller.
- introduces ivi-shell-user-interface.c
This is launched from hmi-controller by launch_hmi_client_process and
invoke a
client process.
The basic flow is as followed,
1/ process invoked
2/ read configuration from weston.ini.
3/ draw png file to surface according to configuration of weston.ini
4/ all parts of UI are ready. request "UI_ready" to draw UI.
5/ Enter event loop
6/ If a surface receives touch/pointer event, followings are invoked
according
to type of event and surface
6-1/ If a surface to launch ivi_application receive touch up, it execs
ivi-application configured in weston.ini.
6-2/ If a surface to switch layout mode receive touch up, it sends a
request,
ivi_hmi_controller_switch_mode, to hmi-controller.
6-3/ If a surface to show workspace having launchers, it sends a
request,
ivi_hmi_controller_home, to hmi-controller.
6-4/ If touch down events happens in workspace,
ivi_hmi_controller_workspace_control is sent to slide workspace.
When control finished, event:
ivi_hmi_controller_workspace_end_control
is received.
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Acked-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
nodist_weston_ivi_shell_user_interface_SOURCES = \
|
|
|
|
protocol/ivi-hmi-controller-client-protocol.h \
|
|
|
|
protocol/ivi-hmi-controller-protocol.c \
|
|
|
|
protocol/ivi-application-client-protocol.h \
|
|
|
|
protocol/ivi-application-protocol.c
|
|
|
|
weston_ivi_shell_user_interface_LDADD = libtoytoolkit.la
|
|
|
|
weston_ivi_shell_user_interface_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if BUILD_FULL_GL_CLIENTS
|
|
|
|
demo_clients += weston-gears
|
|
|
|
weston_gears_SOURCES = clients/gears.c
|
|
|
|
weston_gears_LDADD = libtoytoolkit.la
|
|
|
|
weston_gears_CFLAGS = $(AM_CFLAGS) $(CLIENT_CFLAGS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
BUILT_SOURCES += \
|
|
|
|
protocol/weston-screenshooter-protocol.c \
|
|
|
|
protocol/weston-screenshooter-client-protocol.h \
|
|
|
|
protocol/text-cursor-position-client-protocol.h \
|
|
|
|
protocol/text-cursor-position-protocol.c \
|
|
|
|
protocol/text-input-unstable-v1-protocol.c \
|
|
|
|
protocol/text-input-unstable-v1-client-protocol.h \
|
|
|
|
protocol/input-method-unstable-v1-protocol.c \
|
|
|
|
protocol/input-method-unstable-v1-client-protocol.h \
|
|
|
|
protocol/weston-desktop-shell-client-protocol.h \
|
|
|
|
protocol/weston-desktop-shell-protocol.c \
|
|
|
|
protocol/scaler-client-protocol.h \
|
|
|
|
protocol/scaler-protocol.c \
|
|
|
|
protocol/presentation-time-protocol.c \
|
|
|
|
protocol/presentation-time-client-protocol.h \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-client-protocol.h \
|
|
|
|
protocol/xdg-shell-unstable-v5-protocol.c \
|
|
|
|
protocol/xdg-shell-unstable-v5-client-protocol.h \
|
clients: a reference implementation of UI client how to use ivi-hmi-controller.
- introduces ivi-shell-user-interface.c
This is launched from hmi-controller by launch_hmi_client_process and
invoke a
client process.
The basic flow is as followed,
1/ process invoked
2/ read configuration from weston.ini.
3/ draw png file to surface according to configuration of weston.ini
4/ all parts of UI are ready. request "UI_ready" to draw UI.
5/ Enter event loop
6/ If a surface receives touch/pointer event, followings are invoked
according
to type of event and surface
6-1/ If a surface to launch ivi_application receive touch up, it execs
ivi-application configured in weston.ini.
6-2/ If a surface to switch layout mode receive touch up, it sends a
request,
ivi_hmi_controller_switch_mode, to hmi-controller.
6-3/ If a surface to show workspace having launchers, it sends a
request,
ivi_hmi_controller_home, to hmi-controller.
6-4/ If touch down events happens in workspace,
ivi_hmi_controller_workspace_control is sent to slide workspace.
When control finished, event:
ivi_hmi_controller_workspace_end_control
is received.
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Acked-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
protocol/ivi-hmi-controller-protocol.c \
|
|
|
|
protocol/ivi-hmi-controller-client-protocol.h \
|
|
|
|
protocol/ivi-application-protocol.c \
|
|
|
|
protocol/ivi-application-client-protocol.h
|
|
|
|
|
|
|
|
westondatadir = $(datadir)/weston
|
|
|
|
dist_westondata_DATA = \
|
|
|
|
data/wayland.svg \
|
|
|
|
data/wayland.png \
|
|
|
|
data/pattern.png \
|
|
|
|
data/terminal.png \
|
|
|
|
data/border.png \
|
|
|
|
data/icon_window.png \
|
|
|
|
data/sign_close.png \
|
|
|
|
data/sign_maximize.png \
|
|
|
|
data/sign_minimize.png
|
|
|
|
|
|
|
|
if ENABLE_IVI_SHELL
|
|
|
|
dist_westondata_DATA += \
|
|
|
|
data/background.png \
|
|
|
|
data/tiling.png \
|
|
|
|
data/fullscreen.png \
|
|
|
|
data/panel.png \
|
|
|
|
data/random.png \
|
|
|
|
data/sidebyside.png \
|
|
|
|
data/home.png \
|
|
|
|
data/icon_ivi_clickdot.png \
|
|
|
|
data/icon_ivi_flower.png \
|
|
|
|
data/icon_ivi_simple-egl.png \
|
|
|
|
data/icon_ivi_simple-shm.png \
|
|
|
|
data/icon_ivi_smoke.png
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
if BUILD_WCAP_TOOLS
|
|
|
|
bin_PROGRAMS += wcap-decode
|
|
|
|
|
|
|
|
wcap_decode_SOURCES = \
|
|
|
|
wcap/main.c \
|
|
|
|
wcap/wcap-decode.c \
|
|
|
|
wcap/wcap-decode.h
|
|
|
|
|
|
|
|
wcap_decode_CFLAGS = $(AM_CFLAGS) $(WCAP_CFLAGS)
|
|
|
|
wcap_decode_LDADD = $(WCAP_LIBS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
if ENABLE_DESKTOP_SHELL
|
|
|
|
|
|
|
|
module_LTLIBRARIES += desktop-shell.la
|
|
|
|
|
|
|
|
desktop_shell_la_CPPFLAGS = \
|
|
|
|
-I$(top_builddir)/protocol \
|
|
|
|
-I$(top_srcdir)/shared \
|
|
|
|
-I$(top_srcdir)/src \
|
|
|
|
-I$(top_builddir)/src \
|
|
|
|
-I$(top_builddir)/desktop-shell \
|
|
|
|
-DDATADIR='"$(datadir)"' \
|
|
|
|
-DMODULEDIR='"$(moduledir)"' \
|
|
|
|
-DLIBEXECDIR='"$(libexecdir)"' \
|
|
|
|
-DIN_WESTON
|
|
|
|
|
|
|
|
desktop_shell_la_LDFLAGS = -module -avoid-version
|
|
|
|
desktop_shell_la_LIBADD = $(COMPOSITOR_LIBS) libshared.la
|
|
|
|
desktop_shell_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
desktop_shell_la_SOURCES = \
|
|
|
|
desktop-shell/shell.h \
|
|
|
|
desktop-shell/shell.c \
|
|
|
|
desktop-shell/exposay.c \
|
|
|
|
desktop-shell/input-panel.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_desktop_shell_la_SOURCES = \
|
|
|
|
protocol/weston-desktop-shell-protocol.c \
|
|
|
|
protocol/weston-desktop-shell-server-protocol.h \
|
|
|
|
protocol/xdg-shell-unstable-v5-protocol.c \
|
|
|
|
protocol/xdg-shell-unstable-v5-server-protocol.h
|
|
|
|
|
|
|
|
BUILT_SOURCES += $(nodist_desktop_shell_la_SOURCES)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_FULLSCREEN_SHELL
|
|
|
|
|
|
|
|
module_LTLIBRARIES += fullscreen-shell.la
|
|
|
|
|
|
|
|
fullscreen_shell_la_CPPFLAGS = \
|
|
|
|
-I$(top_builddir)/protocol \
|
|
|
|
-I$(top_srcdir)/shared \
|
|
|
|
-I$(top_srcdir)/src \
|
|
|
|
-I$(top_builddir)/src \
|
|
|
|
-DIN_WESTON
|
|
|
|
|
|
|
|
fullscreen_shell_la_LDFLAGS = -module -avoid-version
|
|
|
|
fullscreen_shell_la_LIBADD = $(COMPOSITOR_LIBS)
|
|
|
|
fullscreen_shell_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
fullscreen_shell_la_SOURCES = \
|
|
|
|
fullscreen-shell/fullscreen-shell.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_fullscreen_shell_la_SOURCES = \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-server-protocol.h
|
|
|
|
|
|
|
|
BUILT_SOURCES += $(nodist_fullscreen_shell_la_SOURCES)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_IVI_SHELL
|
|
|
|
|
|
|
|
module_LTLIBRARIES += \
|
ivi-shell: a reference implementation how to use ivi-layout internal APIs
- hmi-controller.so
- introduces hmi-controller.so
The library is used to manage layout of surfaces/layers. Layout change
is triggered by ivi-hmi-controller protocol, ivi-hmi-controller.xml. A
reference how to use the protocol, see ivi-shell-user-interface.c.
In-Vehicle Infotainment system usually manages properties of
surfaces/layers by only a central component which decide where
surfaces/layers shall be. This is differenct use case from desktop
style; each application can request property of its window via xdg-shell
protocol, like fullscreen and set its to top level. In-Vehicle
Infortainment system doesn't allow each application to chagen them from
its application because of safty reasons. The concept of layer is
simillar with a use case of cursor layer of Destop. For In-Vehicle
Infortainment system, it is extended to all applications. For example,
rearview camera application is assigned to a layer to group several
surfaces, e.g. captured image and drawing lines separately. Central
manaegr can control property of the layer of rearview camera.
This reference show examples to implement the central component as a
module of weston.
Default Scene graph of UI is defined in hmi_controller_create. It
consists of
- In the bottom, a base layer to group surfaces of background, panel,
and buttons
- Next, a application layer to show application surfaces.
- Workspace background layer to show a surface of background image.
- Workspace layer to show launcher to launch application with icons.
Paths to binary and icon are defined in weston.ini. The width of
this layer is longer than the size of screen because a workspace
has several pages and is controlled by motion of input.
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Acked-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
$(ivi_shell) \
|
|
|
|
$(hmi_controller)
|
|
|
|
|
|
|
|
ivi_shell = ivi-shell.la
|
|
|
|
ivi_shell_la_LDFLAGS = -module -avoid-version
|
|
|
|
ivi_shell_la_LIBADD = $(COMPOSITOR_LIBS) libshared.la
|
|
|
|
ivi_shell_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
ivi_shell_la_SOURCES = \
|
|
|
|
ivi-shell/ivi-layout-export.h \
|
|
|
|
ivi-shell/ivi-layout-private.h \
|
|
|
|
ivi-shell/ivi-layout-shell.h \
|
|
|
|
ivi-shell/ivi-layout.c \
|
|
|
|
ivi-shell/ivi-layout-transition.c \
|
|
|
|
ivi-shell/ivi-shell.h \
|
|
|
|
ivi-shell/ivi-shell.c \
|
|
|
|
ivi-shell/input-panel-ivi.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_ivi_shell_la_SOURCES = \
|
|
|
|
protocol/ivi-application-protocol.c \
|
|
|
|
protocol/ivi-application-server-protocol.h
|
|
|
|
|
|
|
|
BUILT_SOURCES += $(nodist_ivi_shell_la_SOURCES)
|
|
|
|
|
ivi-shell: a reference implementation how to use ivi-layout internal APIs
- hmi-controller.so
- introduces hmi-controller.so
The library is used to manage layout of surfaces/layers. Layout change
is triggered by ivi-hmi-controller protocol, ivi-hmi-controller.xml. A
reference how to use the protocol, see ivi-shell-user-interface.c.
In-Vehicle Infotainment system usually manages properties of
surfaces/layers by only a central component which decide where
surfaces/layers shall be. This is differenct use case from desktop
style; each application can request property of its window via xdg-shell
protocol, like fullscreen and set its to top level. In-Vehicle
Infortainment system doesn't allow each application to chagen them from
its application because of safty reasons. The concept of layer is
simillar with a use case of cursor layer of Destop. For In-Vehicle
Infortainment system, it is extended to all applications. For example,
rearview camera application is assigned to a layer to group several
surfaces, e.g. captured image and drawing lines separately. Central
manaegr can control property of the layer of rearview camera.
This reference show examples to implement the central component as a
module of weston.
Default Scene graph of UI is defined in hmi_controller_create. It
consists of
- In the bottom, a base layer to group surfaces of background, panel,
and buttons
- Next, a application layer to show application surfaces.
- Workspace background layer to show a surface of background image.
- Workspace layer to show launcher to launch application with icons.
Paths to binary and icon are defined in weston.ini. The width of
this layer is longer than the size of screen because a workspace
has several pages and is controlled by motion of input.
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Acked-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
hmi_controller = hmi-controller.la
|
|
|
|
hmi_controller_la_LDFLAGS = -module -avoid-version
|
|
|
|
hmi_controller_la_LIBADD = $(COMPOSITOR_LIBS) libshared.la
|
|
|
|
hmi_controller_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
ivi-shell: a reference implementation how to use ivi-layout internal APIs
- hmi-controller.so
- introduces hmi-controller.so
The library is used to manage layout of surfaces/layers. Layout change
is triggered by ivi-hmi-controller protocol, ivi-hmi-controller.xml. A
reference how to use the protocol, see ivi-shell-user-interface.c.
In-Vehicle Infotainment system usually manages properties of
surfaces/layers by only a central component which decide where
surfaces/layers shall be. This is differenct use case from desktop
style; each application can request property of its window via xdg-shell
protocol, like fullscreen and set its to top level. In-Vehicle
Infortainment system doesn't allow each application to chagen them from
its application because of safty reasons. The concept of layer is
simillar with a use case of cursor layer of Destop. For In-Vehicle
Infortainment system, it is extended to all applications. For example,
rearview camera application is assigned to a layer to group several
surfaces, e.g. captured image and drawing lines separately. Central
manaegr can control property of the layer of rearview camera.
This reference show examples to implement the central component as a
module of weston.
Default Scene graph of UI is defined in hmi_controller_create. It
consists of
- In the bottom, a base layer to group surfaces of background, panel,
and buttons
- Next, a application layer to show application surfaces.
- Workspace background layer to show a surface of background image.
- Workspace layer to show launcher to launch application with icons.
Paths to binary and icon are defined in weston.ini. The width of
this layer is longer than the size of screen because a workspace
has several pages and is controlled by motion of input.
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Acked-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
hmi_controller_la_SOURCES = \
|
|
|
|
ivi-shell/ivi-layout-export.h \
|
|
|
|
ivi-shell/hmi-controller.c \
|
|
|
|
shared/helpers.h
|
ivi-shell: a reference implementation how to use ivi-layout internal APIs
- hmi-controller.so
- introduces hmi-controller.so
The library is used to manage layout of surfaces/layers. Layout change
is triggered by ivi-hmi-controller protocol, ivi-hmi-controller.xml. A
reference how to use the protocol, see ivi-shell-user-interface.c.
In-Vehicle Infotainment system usually manages properties of
surfaces/layers by only a central component which decide where
surfaces/layers shall be. This is differenct use case from desktop
style; each application can request property of its window via xdg-shell
protocol, like fullscreen and set its to top level. In-Vehicle
Infortainment system doesn't allow each application to chagen them from
its application because of safty reasons. The concept of layer is
simillar with a use case of cursor layer of Destop. For In-Vehicle
Infortainment system, it is extended to all applications. For example,
rearview camera application is assigned to a layer to group several
surfaces, e.g. captured image and drawing lines separately. Central
manaegr can control property of the layer of rearview camera.
This reference show examples to implement the central component as a
module of weston.
Default Scene graph of UI is defined in hmi_controller_create. It
consists of
- In the bottom, a base layer to group surfaces of background, panel,
and buttons
- Next, a application layer to show application surfaces.
- Workspace background layer to show a surface of background image.
- Workspace layer to show launcher to launch application with icons.
Paths to binary and icon are defined in weston.ini. The width of
this layer is longer than the size of screen because a workspace
has several pages and is controlled by motion of input.
Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Acked-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
10 years ago
|
|
|
nodist_hmi_controller_la_SOURCES = \
|
|
|
|
protocol/ivi-hmi-controller-protocol.c \
|
|
|
|
protocol/ivi-hmi-controller-server-protocol.h
|
|
|
|
|
|
|
|
BUILT_SOURCES += $(nodist_hmi_controller_la_SOURCES)
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
if ENABLE_SCREEN_SHARING
|
|
|
|
|
|
|
|
module_LTLIBRARIES += screen-share.la
|
|
|
|
|
|
|
|
screen_share_la_CPPFLAGS = $(AM_CPPFLAGS) -DBINDIR='"$(bindir)"'
|
|
|
|
screen_share_la_LDFLAGS = -module -avoid-version
|
|
|
|
screen_share_la_LIBADD = \
|
|
|
|
$(COMPOSITOR_LIBS) \
|
|
|
|
$(SCREEN_SHARE_LIBS) \
|
|
|
|
libshared-cairo.la
|
|
|
|
screen_share_la_CFLAGS = \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(SCREEN_SHARE_CFLAGS) \
|
|
|
|
$(AM_CFLAGS)
|
|
|
|
screen_share_la_SOURCES = \
|
|
|
|
src/screen-share.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_screen_share_la_SOURCES = \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-protocol.c \
|
|
|
|
protocol/fullscreen-shell-unstable-v1-client-protocol.h
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_XWAYLAND
|
|
|
|
|
|
|
|
module_LTLIBRARIES += xwayland.la
|
|
|
|
|
|
|
|
xwayland_la_CPPFLAGS = \
|
|
|
|
-I$(top_builddir)/protocol \
|
|
|
|
-I$(top_srcdir)/shared \
|
|
|
|
-I$(top_srcdir)/src \
|
|
|
|
-I$(top_builddir)/src \
|
|
|
|
-I$(top_builddir)/xwayland \
|
|
|
|
-DDATADIR='"$(datadir)"' \
|
|
|
|
-DMODULEDIR='"$(moduledir)"' \
|
|
|
|
-DLIBEXECDIR='"$(libexecdir)"' \
|
|
|
|
-DXSERVER_PATH='"@XSERVER_PATH@"'
|
|
|
|
|
|
|
|
xwayland_la_LDFLAGS = -module -avoid-version
|
|
|
|
xwayland_la_LIBADD = \
|
|
|
|
$(XWAYLAND_LIBS) \
|
|
|
|
$(top_builddir)/libshared-cairo.la
|
|
|
|
xwayland_la_CFLAGS = \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(PIXMAN_CFLAGS) \
|
|
|
|
$(CAIRO_CFLAGS)
|
|
|
|
xwayland_la_SOURCES = \
|
|
|
|
xwayland/xwayland.h \
|
|
|
|
xwayland/window-manager.c \
|
|
|
|
xwayland/selection.c \
|
|
|
|
xwayland/dnd.c \
|
|
|
|
xwayland/launcher.c \
|
|
|
|
xwayland/hash.c \
|
|
|
|
xwayland/hash.h \
|
|
|
|
shared/helpers.h
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Shared utilities
|
|
|
|
#
|
|
|
|
|
|
|
|
noinst_LTLIBRARIES += libshared.la libshared-cairo.la \
|
|
|
|
libzunitc.la libzunitcmain.la
|
|
|
|
|
|
|
|
libshared_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
|
|
|
|
libshared_la_SOURCES = \
|
|
|
|
shared/config-parser.c \
|
|
|
|
shared/option-parser.c \
|
|
|
|
shared/config-parser.h \
|
|
|
|
shared/file-util.c \
|
|
|
|
shared/file-util.h \
|
|
|
|
shared/helpers.h \
|
|
|
|
shared/os-compatibility.c \
|
|
|
|
shared/os-compatibility.h \
|
|
|
|
shared/xalloc.c \
|
|
|
|
shared/xalloc.h
|
|
|
|
|
|
|
|
libshared_cairo_la_CFLAGS = \
|
|
|
|
-DDATADIR='"$(datadir)"' \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
$(COMPOSITOR_CFLAGS) \
|
|
|
|
$(PIXMAN_CFLAGS) \
|
|
|
|
$(CAIRO_CFLAGS) \
|
|
|
|
$(PNG_CFLAGS) \
|
|
|
|
$(WEBP_CFLAGS)
|
|
|
|
|
|
|
|
libshared_cairo_la_LIBADD = \
|
|
|
|
$(PIXMAN_LIBS) \
|
|
|
|
$(CAIRO_LIBS) \
|
|
|
|
$(PNG_LIBS) \
|
|
|
|
$(WEBP_LIBS) \
|
|
|
|
$(JPEG_LIBS)
|
|
|
|
|
|
|
|
libshared_cairo_la_SOURCES = \
|
|
|
|
$(libshared_la_SOURCES) \
|
|
|
|
shared/helpers.h \
|
|
|
|
shared/image-loader.c \
|
|
|
|
shared/image-loader.h \
|
|
|
|
shared/cairo-util.c \
|
|
|
|
shared/frame.c \
|
|
|
|
shared/cairo-util.h
|
|
|
|
|
|
|
|
libzunitc_la_SOURCES = \
|
|
|
|
tools/zunitc/inc/zunitc/zunitc.h \
|
|
|
|
tools/zunitc/inc/zunitc/zunitc_impl.h \
|
|
|
|
tools/zunitc/src/zuc_base_logger.c \
|
|
|
|
tools/zunitc/src/zuc_base_logger.h \
|
|
|
|
tools/zunitc/src/zuc_collector.c \
|
|
|
|
tools/zunitc/src/zuc_collector.h \
|
|
|
|
tools/zunitc/src/zuc_context.h \
|
|
|
|
tools/zunitc/src/zuc_event.h \
|
|
|
|
tools/zunitc/src/zuc_event_listener.h \
|
|
|
|
tools/zunitc/src/zuc_junit_reporter.c \
|
|
|
|
tools/zunitc/src/zuc_junit_reporter.h \
|
|
|
|
tools/zunitc/src/zuc_types.h \
|
|
|
|
tools/zunitc/src/zunitc_impl.c \
|
|
|
|
shared/helpers.h
|
|
|
|
|
|
|
|
libzunitc_la_CFLAGS = \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
-I$(top_srcdir)/tools/zunitc/inc
|
|
|
|
|
|
|
|
libzunitc_la_LIBADD = \
|
|
|
|
libshared.la \
|
|
|
|
$(CLOCK_GETTIME_LIBS)
|
|
|
|
|
|
|
|
if ENABLE_JUNIT_XML
|
|
|
|
libzunitc_la_CFLAGS += \
|
|
|
|
$(LIBXML2_CFLAGS)
|
|
|
|
libzunitc_la_LIBADD += \
|
|
|
|
$(LIBXML2_LIBS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
libzunitcmain_la_SOURCES = \
|
|
|
|
tools/zunitc/src/main.c
|
|
|
|
|
|
|
|
libzunitcmain_la_CFLAGS = \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
-I$(top_srcdir)/tools/zunitc/inc
|
|
|
|
|
|
|
|
libzunitcmain_la_LIBADD = \
|
|
|
|
libzunitc.la \
|
|
|
|
libshared.la
|
|
|
|
|
|
|
|
#
|
|
|
|
# tests subdirectory
|
|
|
|
#
|
|
|
|
|
|
|
|
TESTS = $(internal_tests) $(shared_tests) $(module_tests) $(weston_tests) $(ivi_tests)
|
|
|
|
|
|
|
|
internal_tests = \
|
|
|
|
internal-screenshot.weston
|
|
|
|
|
|
|
|
shared_tests = \
|
|
|
|
config-parser.test \
|
|
|
|
vertex-clip.test \
|
|
|
|
zuctest
|
|
|
|
|
|
|
|
module_tests = \
|
|
|
|
surface-test.la \
|
|
|
|
surface-global-test.la
|
|
|
|
|
|
|
|
weston_tests = \
|
|
|
|
bad_buffer.weston \
|
|
|
|
keyboard.weston \
|
|
|
|
event.weston \
|
|
|
|
button.weston \
|
|
|
|
text.weston \
|
|
|
|
presentation.weston \
|
|
|
|
roles.weston \
|
|
|
|
subsurface.weston \
|
|
|
|
devices.weston
|
|
|
|
|
|
|
|
ivi_tests =
|
|
|
|
|
|
|
|
$(ivi_tests) : $(builddir)/tests/weston-ivi.ini
|
|
|
|
|
|
|
|
AM_TESTS_ENVIRONMENT = \
|
|
|
|
abs_builddir='$(abs_builddir)'; export abs_builddir; \
|
|
|
|
abs_top_srcdir='$(abs_top_srcdir)'; export abs_top_srcdir;
|
|
|
|
|
|
|
|
TEST_EXTENSIONS = .la .weston
|
|
|
|
LA_LOG_COMPILER = $(srcdir)/tests/weston-tests-env
|
|
|
|
WESTON_LOG_COMPILER = $(srcdir)/tests/weston-tests-env
|
|
|
|
|
|
|
|
clean-local:
|
|
|
|
-rm -rf logs
|
|
|
|
-rm -rf $(DOCDIRS)
|
|
|
|
|
|
|
|
# To remove when automake 1.11 support is dropped
|
|
|
|
export abs_builddir
|
|
|
|
|
|
|
|
noinst_LTLIBRARIES += \
|
|
|
|
weston-test.la \
|
|
|
|
$(module_tests) \
|
|
|
|
libtest-runner.la \
|
|
|
|
libtest-client.la
|
|
|
|
|
|
|
|
noinst_PROGRAMS += \
|
|
|
|
$(setbacklight) \
|
|
|
|
$(internal_tests) \
|
|
|
|
$(shared_tests) \
|
|
|
|
$(weston_tests) \
|
|
|
|
$(ivi_tests) \
|
|
|
|
matrix-test
|
|
|
|
|
|
|
|
test_module_ldflags = \
|
|
|
|
-module -avoid-version -rpath $(libdir) $(COMPOSITOR_LIBS)
|
|
|
|
|
|
|
|
surface_global_test_la_SOURCES = tests/surface-global-test.c
|
|
|
|
surface_global_test_la_LDFLAGS = $(test_module_ldflags)
|
|
|
|
surface_global_test_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
|
|
|
|
surface_test_la_SOURCES = tests/surface-test.c
|
|
|
|
surface_test_la_LDFLAGS = $(test_module_ldflags)
|
|
|
|
surface_test_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
|
|
|
|
weston_test_la_LIBADD = $(COMPOSITOR_LIBS) libshared.la
|
|
|
|
weston_test_la_LDFLAGS = $(test_module_ldflags)
|
|
|
|
weston_test_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
weston_test_la_SOURCES = \
|
|
|
|
tests/weston-test.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_weston_test_la_SOURCES = \
|
|
|
|
protocol/weston-test-protocol.c \
|
|
|
|
protocol/weston-test-server-protocol.h
|
|
|
|
|
|
|
|
if ENABLE_EGL
|
|
|
|
weston_test_la_CFLAGS += $(EGL_TESTS_CFLAGS)
|
|
|
|
weston_test_la_LDFLAGS += $(EGL_TESTS_LIBS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
libtest_runner_la_SOURCES = \
|
|
|
|
tests/weston-test-runner.c \
|
|
|
|
tests/weston-test-runner.h
|
|
|
|
libtest_runner_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
|
|
|
|
config_parser_test_SOURCES = tests/config-parser-test.c
|
|
|
|
config_parser_test_LDADD = \
|
|
|
|
libshared.la \
|
|
|
|
$(COMPOSITOR_LIBS) \
|
|
|
|
libzunitc.la \
|
|
|
|
libzunitcmain.la
|
|
|
|
config_parser_test_CFLAGS = \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
-I$(top_srcdir)/tools/zunitc/inc
|
|
|
|
|
|
|
|
vertex_clip_test_SOURCES = \
|
|
|
|
tests/vertex-clip-test.c \
|
|
|
|
shared/helpers.h \
|
|
|
|
src/vertex-clipping.c \
|
|
|
|
src/vertex-clipping.h
|
|
|
|
vertex_clip_test_LDADD = libtest-runner.la -lm $(CLOCK_GETTIME_LIBS)
|
|
|
|
|
|
|
|
libtest_client_la_SOURCES = \
|
|
|
|
tests/weston-test-client-helper.c \
|
|
|
|
tests/weston-test-client-helper.h
|
|
|
|
nodist_libtest_client_la_SOURCES = \
|
|
|
|
protocol/weston-test-protocol.c \
|
|
|
|
protocol/weston-test-client-protocol.h
|
|
|
|
libtest_client_la_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS) $(CAIRO_CFLAGS)
|
|
|
|
libtest_client_la_LIBADD = $(TEST_CLIENT_LIBS) $(CAIRO_LIBS) libshared.la libtest-runner.la
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Internal tests - tests functionality of the testsuite itself
|
|
|
|
#
|
|
|
|
|
|
|
|
internal_screenshot_weston_SOURCES = tests/internal-screenshot-test.c
|
|
|
|
internal_screenshot_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
internal_screenshot_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Weston Tests
|
|
|
|
#
|
|
|
|
|
|
|
|
bad_buffer_weston_SOURCES = tests/bad-buffer-test.c
|
|
|
|
bad_buffer_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
bad_buffer_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
keyboard_weston_SOURCES = tests/keyboard-test.c
|
|
|
|
keyboard_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
keyboard_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
event_weston_SOURCES = tests/event-test.c
|
|
|
|
event_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
event_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
button_weston_SOURCES = tests/button-test.c
|
|
|
|
button_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
button_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
devices_weston_SOURCES = tests/devices-test.c
|
|
|
|
devices_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
devices_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
text_weston_SOURCES = tests/text-test.c
|
|
|
|
nodist_text_weston_SOURCES = \
|
|
|
|
protocol/text-input-unstable-v1-protocol.c \
|
|
|
|
protocol/text-input-unstable-v1-client-protocol.h
|
|
|
|
text_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
text_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
subsurface_weston_SOURCES = tests/subsurface-test.c
|
|
|
|
subsurface_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
subsurface_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
presentation_weston_SOURCES = \
|
|
|
|
tests/presentation-test.c \
|
|
|
|
shared/helpers.h
|
|
|
|
nodist_presentation_weston_SOURCES = \
|
|
|
|
protocol/presentation-time-protocol.c \
|
|
|
|
protocol/presentation-time-client-protocol.h
|
|
|
|
presentation_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
presentation_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
roles_weston_SOURCES = tests/roles-test.c
|
|
|
|
roles_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
roles_weston_LDADD = libtest-client.la
|
|
|
|
|
|
|
|
if ENABLE_EGL
|
|
|
|
weston_tests += buffer-count.weston
|
|
|
|
buffer_count_weston_SOURCES = tests/buffer-count-test.c
|
|
|
|
buffer_count_weston_CFLAGS = $(AM_CFLAGS) $(EGL_TESTS_CFLAGS)
|
|
|
|
buffer_count_weston_LDADD = libtest-client.la $(EGL_TESTS_LIBS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ENABLE_XWAYLAND_TEST
|
|
|
|
weston_tests += xwayland-test.weston
|
|
|
|
xwayland_test_weston_SOURCES = tests/xwayland-test.c
|
|
|
|
xwayland_test_weston_CFLAGS = $(AM_CFLAGS) $(XWAYLAND_TEST_CFLAGS)
|
|
|
|
xwayland_test_weston_LDADD = libtest-client.la $(XWAYLAND_TEST_LIBS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
matrix_test_SOURCES = \
|
|
|
|
tests/matrix-test.c \
|
|
|
|
shared/matrix.c \
|
|
|
|
shared/matrix.h
|
|
|
|
matrix_test_CPPFLAGS = -DUNIT_TEST
|
|
|
|
matrix_test_LDADD = -lm $(CLOCK_GETTIME_LIBS)
|
|
|
|
|
|
|
|
if ENABLE_IVI_SHELL
|
tests: ivi_layout test infrastructure
Testing the ivi_layout API requires two things:
- the tests must be written as a controller module to access the API
- the tests need a helper client to create some objects that can then be
managed via the API
This patch adds all the infrastructure and two different kinds of
example tests.
Internal ivi-shell (ivi_layout) API tests are listed as ivi-*.la files
in TESTS in Makefile.am. Weston-tests-env detects these, and runs Weston
with ivi-shell, and loads the given module as a controller module, not
as a normal plugin.
The test controller module ivi-*.la will launch a helper client. For
ivi-layout-test.la the helper client is ivi-layout.ivi.
The helper client uses the weston-test-runner framework to fork and exec
each TEST with a fresh connection to the compositor.
The actual test is triggered by the weston_test_runner protocol
interface, a new addition to weston-test.xml. The helper client uses
weston_test_runner to trigger a test, and the server side of the
interface is implemented by the test controller module
(ivi-layout-test.la).
The server side of weston_test_runner uses the same trick as
weston-test-runner.h to gather a list of defined tests. A test is
defined with the RUNNER_TEST macro.
If a test defined by RUNNER_TEST succeeds, an event is sent to the
helper client that it can continue (or exit). If a test fails, a fatal
protocol error is sent to the helper client.
Once the helper client has iterated over all of its tests, it signals
the batch success/failure via process exit code. That is cought in the
test controller module, and forwarded as Weston's exit code.
In summary: each ivi_layout test is a combination of a client side
helper/setup and server side actual tests.
v2: Load weston-test.so, because create_client() needs it.
v3: add a comment about IVI_TEST_SURFACE_ID_BASE.
v4: Rebased to upstream weston-tests-env changes.
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Reviewed-by: Derek Foreman <derekf@osg.samsung.com> (v2)
10 years ago
|
|
|
module_tests += \
|
|
|
|
ivi-layout-internal-test.la \
|
tests: ivi_layout test infrastructure
Testing the ivi_layout API requires two things:
- the tests must be written as a controller module to access the API
- the tests need a helper client to create some objects that can then be
managed via the API
This patch adds all the infrastructure and two different kinds of
example tests.
Internal ivi-shell (ivi_layout) API tests are listed as ivi-*.la files
in TESTS in Makefile.am. Weston-tests-env detects these, and runs Weston
with ivi-shell, and loads the given module as a controller module, not
as a normal plugin.
The test controller module ivi-*.la will launch a helper client. For
ivi-layout-test.la the helper client is ivi-layout.ivi.
The helper client uses the weston-test-runner framework to fork and exec
each TEST with a fresh connection to the compositor.
The actual test is triggered by the weston_test_runner protocol
interface, a new addition to weston-test.xml. The helper client uses
weston_test_runner to trigger a test, and the server side of the
interface is implemented by the test controller module
(ivi-layout-test.la).
The server side of weston_test_runner uses the same trick as
weston-test-runner.h to gather a list of defined tests. A test is
defined with the RUNNER_TEST macro.
If a test defined by RUNNER_TEST succeeds, an event is sent to the
helper client that it can continue (or exit). If a test fails, a fatal
protocol error is sent to the helper client.
Once the helper client has iterated over all of its tests, it signals
the batch success/failure via process exit code. That is cought in the
test controller module, and forwarded as Weston's exit code.
In summary: each ivi_layout test is a combination of a client side
helper/setup and server side actual tests.
v2: Load weston-test.so, because create_client() needs it.
v3: add a comment about IVI_TEST_SURFACE_ID_BASE.
v4: Rebased to upstream weston-tests-env changes.
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Reviewed-by: Derek Foreman <derekf@osg.samsung.com> (v2)
10 years ago
|
|
|
ivi-layout-test.la
|
|
|
|
|
|
|
|
ivi_layout_internal_test_la_LIBADD = $(COMPOSITOR_LIBS)
|
|
|
|
ivi_layout_internal_test_la_LDFLAGS = $(test_module_ldflags)
|
|
|
|
ivi_layout_internal_test_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
ivi_layout_internal_test_la_SOURCES = \
|
|
|
|
tests/ivi_layout-internal-test.c
|
|
|
|
|
tests: ivi_layout test infrastructure
Testing the ivi_layout API requires two things:
- the tests must be written as a controller module to access the API
- the tests need a helper client to create some objects that can then be
managed via the API
This patch adds all the infrastructure and two different kinds of
example tests.
Internal ivi-shell (ivi_layout) API tests are listed as ivi-*.la files
in TESTS in Makefile.am. Weston-tests-env detects these, and runs Weston
with ivi-shell, and loads the given module as a controller module, not
as a normal plugin.
The test controller module ivi-*.la will launch a helper client. For
ivi-layout-test.la the helper client is ivi-layout.ivi.
The helper client uses the weston-test-runner framework to fork and exec
each TEST with a fresh connection to the compositor.
The actual test is triggered by the weston_test_runner protocol
interface, a new addition to weston-test.xml. The helper client uses
weston_test_runner to trigger a test, and the server side of the
interface is implemented by the test controller module
(ivi-layout-test.la).
The server side of weston_test_runner uses the same trick as
weston-test-runner.h to gather a list of defined tests. A test is
defined with the RUNNER_TEST macro.
If a test defined by RUNNER_TEST succeeds, an event is sent to the
helper client that it can continue (or exit). If a test fails, a fatal
protocol error is sent to the helper client.
Once the helper client has iterated over all of its tests, it signals
the batch success/failure via process exit code. That is cought in the
test controller module, and forwarded as Weston's exit code.
In summary: each ivi_layout test is a combination of a client side
helper/setup and server side actual tests.
v2: Load weston-test.so, because create_client() needs it.
v3: add a comment about IVI_TEST_SURFACE_ID_BASE.
v4: Rebased to upstream weston-tests-env changes.
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Reviewed-by: Derek Foreman <derekf@osg.samsung.com> (v2)
10 years ago
|
|
|
ivi_layout_test_la_LIBADD = $(COMPOSITOR_LIBS)
|
|
|
|
ivi_layout_test_la_LDFLAGS = $(test_module_ldflags)
|
|
|
|
ivi_layout_test_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
tests: ivi_layout test infrastructure
Testing the ivi_layout API requires two things:
- the tests must be written as a controller module to access the API
- the tests need a helper client to create some objects that can then be
managed via the API
This patch adds all the infrastructure and two different kinds of
example tests.
Internal ivi-shell (ivi_layout) API tests are listed as ivi-*.la files
in TESTS in Makefile.am. Weston-tests-env detects these, and runs Weston
with ivi-shell, and loads the given module as a controller module, not
as a normal plugin.
The test controller module ivi-*.la will launch a helper client. For
ivi-layout-test.la the helper client is ivi-layout.ivi.
The helper client uses the weston-test-runner framework to fork and exec
each TEST with a fresh connection to the compositor.
The actual test is triggered by the weston_test_runner protocol
interface, a new addition to weston-test.xml. The helper client uses
weston_test_runner to trigger a test, and the server side of the
interface is implemented by the test controller module
(ivi-layout-test.la).
The server side of weston_test_runner uses the same trick as
weston-test-runner.h to gather a list of defined tests. A test is
defined with the RUNNER_TEST macro.
If a test defined by RUNNER_TEST succeeds, an event is sent to the
helper client that it can continue (or exit). If a test fails, a fatal
protocol error is sent to the helper client.
Once the helper client has iterated over all of its tests, it signals
the batch success/failure via process exit code. That is cought in the
test controller module, and forwarded as Weston's exit code.
In summary: each ivi_layout test is a combination of a client side
helper/setup and server side actual tests.
v2: Load weston-test.so, because create_client() needs it.
v3: add a comment about IVI_TEST_SURFACE_ID_BASE.
v4: Rebased to upstream weston-tests-env changes.
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Reviewed-by: Derek Foreman <derekf@osg.samsung.com> (v2)
10 years ago
|
|
|
ivi_layout_test_la_SOURCES = \
|
|
|
|
tests/ivi_layout-test-plugin.c \
|
|
|
|
tests/ivi-test.h \
|
|
|
|
shared/helpers.h
|
tests: ivi_layout test infrastructure
Testing the ivi_layout API requires two things:
- the tests must be written as a controller module to access the API
- the tests need a helper client to create some objects that can then be
managed via the API
This patch adds all the infrastructure and two different kinds of
example tests.
Internal ivi-shell (ivi_layout) API tests are listed as ivi-*.la files
in TESTS in Makefile.am. Weston-tests-env detects these, and runs Weston
with ivi-shell, and loads the given module as a controller module, not
as a normal plugin.
The test controller module ivi-*.la will launch a helper client. For
ivi-layout-test.la the helper client is ivi-layout.ivi.
The helper client uses the weston-test-runner framework to fork and exec
each TEST with a fresh connection to the compositor.
The actual test is triggered by the weston_test_runner protocol
interface, a new addition to weston-test.xml. The helper client uses
weston_test_runner to trigger a test, and the server side of the
interface is implemented by the test controller module
(ivi-layout-test.la).
The server side of weston_test_runner uses the same trick as
weston-test-runner.h to gather a list of defined tests. A test is
defined with the RUNNER_TEST macro.
If a test defined by RUNNER_TEST succeeds, an event is sent to the
helper client that it can continue (or exit). If a test fails, a fatal
protocol error is sent to the helper client.
Once the helper client has iterated over all of its tests, it signals
the batch success/failure via process exit code. That is cought in the
test controller module, and forwarded as Weston's exit code.
In summary: each ivi_layout test is a combination of a client side
helper/setup and server side actual tests.
v2: Load weston-test.so, because create_client() needs it.
v3: add a comment about IVI_TEST_SURFACE_ID_BASE.
v4: Rebased to upstream weston-tests-env changes.
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Reviewed-by: Derek Foreman <derekf@osg.samsung.com> (v2)
10 years ago
|
|
|
nodist_ivi_layout_test_la_SOURCES = \
|
|
|
|
protocol/weston-test-protocol.c \
|
|
|
|
protocol/weston-test-server-protocol.h
|
|
|
|
|
|
|
|
ivi_tests += \
|
|
|
|
ivi-shell-app.weston
|
|
|
|
|
|
|
|
ivi_shell_app_weston_SOURCES = tests/ivi-shell-app-test.c
|
|
|
|
nodist_ivi_shell_app_weston_SOURCES = \
|
|
|
|
protocol/ivi-application-protocol.c \
|
|
|
|
protocol/ivi-application-client-protocol.h
|
|
|
|
ivi_shell_app_weston_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
ivi_shell_app_weston_LDADD = libtest-client.la
|
tests: ivi_layout test infrastructure
Testing the ivi_layout API requires two things:
- the tests must be written as a controller module to access the API
- the tests need a helper client to create some objects that can then be
managed via the API
This patch adds all the infrastructure and two different kinds of
example tests.
Internal ivi-shell (ivi_layout) API tests are listed as ivi-*.la files
in TESTS in Makefile.am. Weston-tests-env detects these, and runs Weston
with ivi-shell, and loads the given module as a controller module, not
as a normal plugin.
The test controller module ivi-*.la will launch a helper client. For
ivi-layout-test.la the helper client is ivi-layout.ivi.
The helper client uses the weston-test-runner framework to fork and exec
each TEST with a fresh connection to the compositor.
The actual test is triggered by the weston_test_runner protocol
interface, a new addition to weston-test.xml. The helper client uses
weston_test_runner to trigger a test, and the server side of the
interface is implemented by the test controller module
(ivi-layout-test.la).
The server side of weston_test_runner uses the same trick as
weston-test-runner.h to gather a list of defined tests. A test is
defined with the RUNNER_TEST macro.
If a test defined by RUNNER_TEST succeeds, an event is sent to the
helper client that it can continue (or exit). If a test fails, a fatal
protocol error is sent to the helper client.
Once the helper client has iterated over all of its tests, it signals
the batch success/failure via process exit code. That is cought in the
test controller module, and forwarded as Weston's exit code.
In summary: each ivi_layout test is a combination of a client side
helper/setup and server side actual tests.
v2: Load weston-test.so, because create_client() needs it.
v3: add a comment about IVI_TEST_SURFACE_ID_BASE.
v4: Rebased to upstream weston-tests-env changes.
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Reviewed-by: Derek Foreman <derekf@osg.samsung.com> (v2)
10 years ago
|
|
|
|
|
|
|
noinst_PROGRAMS += ivi-layout.ivi
|
|
|
|
|
|
|
|
ivi_layout_ivi_SOURCES = \
|
|
|
|
tests/ivi_layout-test.c \
|
|
|
|
tests/ivi-test.h \
|
|
|
|
shared/helpers.h
|
tests: ivi_layout test infrastructure
Testing the ivi_layout API requires two things:
- the tests must be written as a controller module to access the API
- the tests need a helper client to create some objects that can then be
managed via the API
This patch adds all the infrastructure and two different kinds of
example tests.
Internal ivi-shell (ivi_layout) API tests are listed as ivi-*.la files
in TESTS in Makefile.am. Weston-tests-env detects these, and runs Weston
with ivi-shell, and loads the given module as a controller module, not
as a normal plugin.
The test controller module ivi-*.la will launch a helper client. For
ivi-layout-test.la the helper client is ivi-layout.ivi.
The helper client uses the weston-test-runner framework to fork and exec
each TEST with a fresh connection to the compositor.
The actual test is triggered by the weston_test_runner protocol
interface, a new addition to weston-test.xml. The helper client uses
weston_test_runner to trigger a test, and the server side of the
interface is implemented by the test controller module
(ivi-layout-test.la).
The server side of weston_test_runner uses the same trick as
weston-test-runner.h to gather a list of defined tests. A test is
defined with the RUNNER_TEST macro.
If a test defined by RUNNER_TEST succeeds, an event is sent to the
helper client that it can continue (or exit). If a test fails, a fatal
protocol error is sent to the helper client.
Once the helper client has iterated over all of its tests, it signals
the batch success/failure via process exit code. That is cought in the
test controller module, and forwarded as Weston's exit code.
In summary: each ivi_layout test is a combination of a client side
helper/setup and server side actual tests.
v2: Load weston-test.so, because create_client() needs it.
v3: add a comment about IVI_TEST_SURFACE_ID_BASE.
v4: Rebased to upstream weston-tests-env changes.
Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Reviewed-by: Derek Foreman <derekf@osg.samsung.com> (v2)
10 years ago
|
|
|
nodist_ivi_layout_ivi_SOURCES = \
|
|
|
|
protocol/ivi-application-protocol.c \
|
|
|
|
protocol/ivi-application-client-protocol.h
|
|
|
|
ivi_layout_ivi_CFLAGS = $(AM_CFLAGS) $(TEST_CLIENT_CFLAGS)
|
|
|
|
ivi_layout_ivi_LDADD = libtest-client.la
|
|
|
|
endif
|
|
|
|
|
|
|
|
if BUILD_SETBACKLIGHT
|
|
|
|
noinst_PROGRAMS += setbacklight
|
|
|
|
setbacklight_SOURCES = \
|
|
|
|
tests/setbacklight.c \
|
|
|
|
src/libbacklight.c \
|
|
|
|
src/libbacklight.h
|
|
|
|
setbacklight_CFLAGS = $(AM_CFLAGS) $(SETBACKLIGHT_CFLAGS)
|
|
|
|
setbacklight_LDADD = $(SETBACKLIGHT_LIBS)
|
|
|
|
endif
|
|
|
|
|
|
|
|
all-local: zuctest$(EXEEXT)
|
|
|
|
|
|
|
|
noinst_PROGRAMS += zuctest$(EXEEXT)
|
|
|
|
|
|
|
|
zuctest_LDADD = \
|
|
|
|
libzunitc.la \
|
|
|
|
libzunitcmain.la
|
|
|
|
|
|
|
|
zuctest_CFLAGS = \
|
|
|
|
$(AM_CFLAGS) \
|
|
|
|
-I$(top_srcdir)/tools/zunitc/inc
|
|
|
|
|
|
|
|
zuctest_SOURCES = \
|
|
|
|
tools/zunitc/test/fixtures_test.c \
|
|
|
|
tools/zunitc/test/zunitc_test.c
|
|
|
|
|
|
|
|
EXTRA_DIST += \
|
|
|
|
tests/weston-tests-env \
|
|
|
|
tests/internal-screenshot.ini \
|
|
|
|
tests/reference/internal-screenshot-bad-00.png \
|
|
|
|
tests/reference/internal-screenshot-good-00.png
|
|
|
|
|
|
|
|
BUILT_SOURCES += \
|
|
|
|
protocol/weston-test-protocol.c \
|
|
|
|
protocol/weston-test-server-protocol.h \
|
|
|
|
protocol/weston-test-client-protocol.h \
|
|
|
|
protocol/text-input-unstable-v1-protocol.c \
|
|
|
|
protocol/text-input-unstable-v1-client-protocol.h
|
|
|
|
|
|
|
|
EXTRA_DIST += \
|
|
|
|
protocol/weston-desktop-shell.xml \
|
|
|
|
protocol/weston-screenshooter.xml \
|
|
|
|
protocol/text-cursor-position.xml \
|
|
|
|
protocol/weston-test.xml \
|
|
|
|
protocol/scaler.xml \
|
|
|
|
protocol/ivi-application.xml \
|
|
|
|
protocol/ivi-hmi-controller.xml
|
|
|
|
|
|
|
|
#
|
|
|
|
# manual test modules in tests subdirectory
|
|
|
|
#
|
|
|
|
|
|
|
|
noinst_LTLIBRARIES += \
|
|
|
|
surface-screenshot.la
|
|
|
|
|
|
|
|
surface_screenshot_la_LIBADD = $(COMPOSITOR_LIBS) libshared.la
|
|
|
|
surface_screenshot_la_LDFLAGS = $(test_module_ldflags)
|
|
|
|
surface_screenshot_la_CFLAGS = $(AM_CFLAGS) $(COMPOSITOR_CFLAGS)
|
|
|
|
surface_screenshot_la_SOURCES = tests/surface-screenshot.c
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Documentation
|
|
|
|
#
|
|
|
|
|
|
|
|
man_MANS = weston.1 weston.ini.5
|
|
|
|
|
|
|
|
if ENABLE_DRM_COMPOSITOR
|
|
|
|
man_MANS += weston-drm.7
|
|
|
|
endif
|
|
|
|
|
|
|
|
MAN_SUBSTS = \
|
|
|
|
-e 's|__weston_native_backend__|$(WESTON_NATIVE_BACKEND)|g' \
|
|
|
|
-e 's|__weston_modules_dir__|$(pkglibdir)|g' \
|
|
|
|
-e 's|__weston_shell_client__|$(WESTON_SHELL_CLIENT)|g' \
|
|
|
|
-e 's|__version__|$(PACKAGE_VERSION)|g'
|
|
|
|
|
|
|
|
SUFFIXES = .1 .5 .7 .man
|
|
|
|
|
|
|
|
%.1 %.5 %.7 : man/%.man
|
|
|
|
$(AM_V_GEN)$(SED) $(MAN_SUBSTS) < $< > $@
|
|
|
|
|
|
|
|
EXTRA_DIST += \
|
|
|
|
man/weston.man \
|
|
|
|
man/weston-drm.man \
|
|
|
|
man/weston.ini.man
|
|
|
|
|
|
|
|
CLEANFILES += $(man_MANS)
|
|
|
|
|
|
|
|
if ENABLE_DEVDOCS
|
|
|
|
DOXYGEN_INDICES = docs/developer/html/index.html docs/tools/html/index.html
|
|
|
|
|
|
|
|
docs/developer/html/index.html: doc/doxygen/tooldev.doxygen | docs/developer
|
|
|
|
cd doc/doxygen && $(DOXYGEN) tooldev.doxygen
|
|
|
|
|
|
|
|
docs/tools/html/index.html: doc/doxygen/tools.doxygen | docs/tools
|
|
|
|
cd doc/doxygen && $(DOXYGEN) tools.doxygen
|
|
|
|
endif
|
|
|
|
|
|
|
|
DOCDIRS = \
|
|
|
|
docs/developer \
|
|
|
|
docs/tools
|
|
|
|
|
|
|
|
$(DOCDIRS):
|
|
|
|
$(MKDIR_P) $@
|
|
|
|
|
|
|
|
.PHONY: doc $(DOXYGEN_INDICES)
|
|
|
|
|
|
|
|
doc: $(DOXYGEN_INDICES)
|
|
|
|
|
|
|
|
.SECONDEXPANSION:
|
|
|
|
|
|
|
|
define protostability
|
|
|
|
$(if $(findstring unstable,$1),unstable,stable)
|
|
|
|
endef
|
|
|
|
|
|
|
|
define protoname
|
|
|
|
$(shell echo $1 | sed 's/\([a-z\-]\+\)-[a-z]\+-v[0-9]\+/\1/')
|
|
|
|
endef
|
|
|
|
|
|
|
|
protocol/%-protocol.c : $(WAYLAND_PROTOCOLS_DATADIR)/$$(call protostability,$$*)/$$(call protoname,$$*)/$$*.xml
|
|
|
|
$(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) code < $< > $@
|
|
|
|
|
|
|
|
protocol/%-server-protocol.h : $(WAYLAND_PROTOCOLS_DATADIR)/$$(call protostability,$$*)/$$(call protoname,$$*)/$$*.xml
|
|
|
|
$(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) server-header < $< > $@
|
|
|
|
|
|
|
|
protocol/%-client-protocol.h : $(WAYLAND_PROTOCOLS_DATADIR)/$$(call protostability,$$*)/$$(call protoname,$$*)/$$*.xml
|
|
|
|
$(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) client-header < $< > $@
|
|
|
|
|
|
|
|
protocol/%-protocol.c : $(top_srcdir)/protocol/%.xml
|
|
|
|
$(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) code < $< > $@
|
|
|
|
|
|
|
|
protocol/%-server-protocol.h : $(top_srcdir)/protocol/%.xml
|
|
|
|
$(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) server-header < $< > $@
|
|
|
|
|
|
|
|
protocol/%-client-protocol.h : $(top_srcdir)/protocol/%.xml
|
|
|
|
$(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(wayland_scanner) client-header < $< > $@
|