X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=Makefile.am;h=8f97c06cb7b58de5155b6ad00b547fac4f709631;hb=refs%2Fheads%2Ftizen_3.0_ivi;hp=3da9dd729c69345aedc476cf4e89ead2cd7ecf6c;hpb=9d2018f52184709bc72b58126fa23354c3316c09;p=platform%2Fupstream%2Fkmscon.git diff --git a/Makefile.am b/Makefile.am index 3da9dd7..8f97c06 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,27 +1,43 @@ # # Kmscon - Global Makefile -# Copyright (c) 2012 David Herrmann +# Copyright (c) 2012-2013 David Herrmann # -ACLOCAL_AMFLAGS = -I m4 -SUBDIRS = \ - . +# +# Global Configurations and Initializations +# + +ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS} +AM_MAKEFLAGS = --no-print-directory +AUTOMAKE_OPTIONS = color-tests +AM_DISTCHECK_CONFIGURE_FLAGS = --enable-all + +SUBDIRS = . + +.DELETE_ON_ERROR: + include_HEADERS = EXTRA_DIST = \ README \ COPYING \ - NEWS + NEWS \ + docs/kmscon.service \ + docs/kmsconvt@.service CLEANFILES = pkgconfigdir = $(libdir)/pkgconfig pkgconfig_DATA = +MANPAGES = +MANPAGES_ALIASES = +TPHONY = bin_PROGRAMS = check_PROGRAMS = -noinst_PROGRAMS = \ - genshader \ - genunifont -noinst_LTLIBRARIES = +noinst_PROGRAMS = lib_LTLIBRARIES = +noinst_LTLIBRARIES = + +moduledir = $(libdir)/kmscon +module_LTLIBRARIES = # # Default CFlags @@ -36,12 +52,25 @@ lib_LTLIBRARIES = # AM_CFLAGS = \ - -Wall + -Wall \ + -pipe \ + -fno-common \ + -ffast-math \ + -fdiagnostics-show-option \ + -fno-strict-aliasing \ + -fvisibility=hidden \ + -ffunction-sections \ + -fdata-sections \ + -fstack-protector AM_CPPFLAGS = \ + -DBUILD_MODULE_DIR='"$(moduledir)"' \ -include $(top_builddir)/config.h \ -I $(srcdir)/src AM_LDFLAGS = \ - -Wl,--as-needed + -Wl,--as-needed \ + -Wl,--gc-sections \ + -Wl,-z,relro \ + -Wl,-z,now if BUILD_ENABLE_DEBUG AM_CFLAGS += -g @@ -54,33 +83,154 @@ AM_CFLAGS += -O0 endif # +# GIT-HEAD helper +# The file ./src/shl_githead.c contains a constant "shl_git_head" which is +# defined to the string returned by "git describe". We need to adjust this +# string for every build and correctly rebuild any sources that depend on it. +# Therefore, you should use this file rarely as it causes rebuilds on every +# git-commit. +# +# We have a helper-script ./src/genversion.sh that takes as argument the source +# file and creates it if necessary. It updates it only if the new git-describe +# string is different to the old one. So the file is only modified on changes. +# Hence, we can use it as normal dependency in this Makefile. +# However, we need to run this script on _every_ "make" invocation before any +# recipy is executed. To achieve this, we use $(shell ...) and assign it to a +# "simply expanded" variable (:=) so the shell command is executed on +# variable-declaration and not during expansion. +# +# Note that we must not clean ./src/shl_githead.c ever! If we would, a +# distribution tarball might delete that file and have no way to recreate it. +# We could delete it on something like "make maintainerclean", but then again, +# it seems unnecessary so lets simply not clean it at all. +# +# If the helper-script is executed in a directory that is not a git-repository +# (like a distribution tarball) and shl_githead.c exists, then it does nothing +# as it expects shl_githead.c to be correctly written by "make dist". +# However, if shl_githead.c does not exist, it will print a warning and write +# an unknown random git-revision. +# This guarantees, that shl_githead.c is always present and has the most correct +# value that we can get under any conditions. +# +# The $(emptyvariable) expansion below is used for broken $(shell ...) +# syntax-highlighting algorithms in many existing editors. +# + +EXTRA_DIST += src/genversion.sh +GITHEAD:=$(shell $(emptyvariable)"$(srcdir)/src/genversion.sh" "$(srcdir)/src/shl_githead.c") + +# +# Binary File Compiler +# This target gets as input a binary file *.bin and produces an ELF/etc. output +# object file *.bin.o and the corresponding libtool file *.bin.lo. +# Note that we fake the libtool object files as there is no way to make libtool +# create it. The comments in the .lo file are mandatory so don't remove them! +# + +CLEANFILES += src/*.bin.lo src/*.bin.o + +src/%.bin.lo: src/%.bin + $(AM_V_GEN)$(LD) -r -o "src/$*.bin.o" -z noexecstack --format=binary "$<" + $(AM_V_at)$(OBJCOPY) --rename-section .data=.rodata,alloc,load,readonly,data,contents "src/$*.bin.o" + $(AM_V_at)echo "# $@ - a libtool object file" >"$@" + $(AM_V_at)echo "# Generated by $(shell $(LIBTOOL) --version | head -n 1)" >>"$@" + $(AM_V_at)echo "#" >>"$@" + $(AM_V_at)echo "# Please DO NOT delete this file!" >>"$@" + $(AM_V_at)echo "# It is necessary for linking the library." >>"$@" + $(AM_V_at)echo >>"$@" + $(AM_V_at)echo "# Name of the PIC object." >>"$@" + $(AM_V_at)echo "pic_object='$*.bin.o'" >>"$@" + $(AM_V_at)echo >>"$@" + $(AM_V_at)echo "# Name of the non-PIC object" >>"$@" + $(AM_V_at)echo "non_pic_object='$*.bin.o'" >>"$@" + $(AM_V_at)echo >>"$@" + +# +# Shader Converter +# We use a few built-in shader files. To reduce memory-consumption, this helper +# removes useless lines from the shaders before they are compiled into an object +# file. +# +# Following regexp are used to remove characters/lines: +# ^/*.*$ Start of multi-line comment +# ^ *.*$ Multi-line comment body +# ^[ \t]* Indentation whitespace +# [\r\n] Newlines +# + +CLEANFILES += src/*.vert.bin src/*.frag.bin +SHADER_SED = -e 's/^\/\*.*$$//' -e 's/^ \*.*$$//' -e 's/^[ \t]*//' +SHADER_TR = -d "\r\n" + +src/%.vert.bin: $(top_srcdir)/src/%.vert + $(AM_V_at)$(SED) $(SHADER_SED) "$<" | tr $(SHADER_TR) >"$@" + +src/%.frag.bin: $(top_srcdir)/src/%.frag + $(AM_V_at)$(SED) $(SHADER_SED) "$<" | tr $(SHADER_TR) >"$@" + +# +# XKB Fallback Converter +# We use a static built-in XKB fallback keymap. To avoid huge memory consumption +# we remove useless lines/characters first. +# We also append an ASCII 0 character so it can be used as regular C-string. +# +# Following regexp are used to remove characters/lines: +# *= * Whitespace around assignments +# *, * Whitespace around commatas +# *[][{}()] * Whitespace around braces +# ^[ \t]* Indentation whitespace +# [\r\n] Newlines +# + +CLEANFILES += src/*.xkb.bin +XKB_SED = -e 's/^[ \t]*//' -e 's/ *\([,=]\) */\1/g' -e 's/ *\([][{}()]\) */\1/g' +XKB_TR = -d "\r\n" + +src/%.xkb.bin: $(top_srcdir)/src/%.xkb + $(AM_V_at)$(SED) $(XKB_SED) "$<" | tr $(XKB_TR) >"$@" + $(AM_V_at)echo -ne "\x00" >>"$@" + +# # SHL - Static Helper Library # The SHL subsystem contains several small code pieces used all over kmscon and # other applications. # -# Simply include $(SHL_*) in your source-file list. Except for SHL_MISC none of -# these have external dependencies. SHL_MISC needs xkbcommon. -# -SHL_DLIST = \ - src/shl_dlist.h -SHL_ARRAY = \ - src/shl_array.h -SHL_HASHTABLE = \ +noinst_LTLIBRARIES += libshl.la + +libshl_la_SOURCES = \ + src/shl_githead.h \ + src/shl_githead.c \ + src/shl_dlist.h \ + src/shl_array.h \ src/shl_hashtable.h \ external/htable.h \ - external/htable.c -SHL_RING = \ - src/shl_ring.h -SHL_TIMER = \ - src/shl_timer.h -SHL_LLOG = \ - src/shl_llog.h -SHL_HOOK = \ + external/htable.c \ + src/shl_ring.h \ + src/shl_timer.h \ + src/shl_llog.h \ + src/shl_log.h \ + src/shl_log.c \ src/shl_hook.h \ - $(SHL_DLIST) -SHL_MISC = \ - src/shl_misc.h + src/shl_misc.h \ + src/shl_register.h \ + src/shl_flagset.h +libshl_la_CPPFLAGS = \ + $(AM_CPPFLAGS) \ + $(XKBCOMMON_CFLAGS) \ + -pthread +libshl_la_LDFLAGS = \ + $(AM_LDFLAGS) \ + -pthread +libshl_la_LIBADD = \ + $(AM_LIBADD) \ + $(XKBCOMMON_LIBS) + +if BUILD_HAVE_GLES2 +libshl_la_SOURCES += src/shl_gl.h src/shl_gl_shader.c src/shl_gl_math.c +libshl_la_CPPFLAGS += $(GLES2_CFLAGS) +libshl_la_LIBADD += $(GLES2_LIBS) +endif # # libeloop @@ -88,74 +238,15 @@ SHL_MISC = \ # compiled into a separate object to allow using it in several other programs. # -if BUILD_ENABLE_ELOOP -lib_LTLIBRARIES += libeloop.la -include_HEADERS += src/eloop.h -pkgconfig_DATA += src/libeloop.pc -endif +noinst_LTLIBRARIES += libeloop.la libeloop_la_SOURCES = \ - $(SHL_DLIST) \ - $(SHL_LLOG) \ - $(SHL_HOOK) \ src/eloop.h \ src/eloop.c -libeloop_la_CPPFLAGS = \ - $(AM_CPPFLAGS) -libeloop_la_LIBADD = -libeloop_la_LDFLAGS = \ - -version-info 1:0:0 - - -if BUILD_ENABLE_ELOOP_DBUS -libeloop_la_SOURCES += \ - external/dbus-common.h \ - external/dbus-loop.h \ - external/dbus-loop.c -libeloop_la_CPPFLAGS += \ - $(DBUS_CFLAGS) -libeloop_la_LIBADD += \ - $(DBUS_LIBS) -endif - -# -# libtsm -# The Terminal-emulator State Machine is a library that implements the whole VTE -# layer and everything related to it. It has no external dependencies so it can -# be used to implement any kind of terminal emulator or debugger. -# - -if BUILD_ENABLE_TSM -lib_LTLIBRARIES += \ - libtsm.la -include_HEADERS += \ - src/tsm_screen.h \ - src/tsm_unicode.h \ - src/tsm_vte.h -pkgconfig_DATA += \ - src/libtsm.pc -endif - -libtsm_la_SOURCES = \ - $(SHL_LLOG) \ - $(SHL_TIMER) \ - $(SHL_ARRAY) \ - $(SHL_HASHTABLE) \ - src/tsm_screen.h \ - src/tsm_screen.c \ - src/tsm_unicode.h \ - src/tsm_unicode.c \ - src/tsm_vte.h \ - src/tsm_vte.c \ - src/tsm_vte_charsets.c - -libtsm_la_CPPFLAGS = \ - $(AM_CPPFLAGS) \ - $(XKBCOMMON_CFLAGS) -libtsm_la_LDFLAGS = \ - $(XKBCOMMON_LIBS) \ - -version-info 1:0:0 +libeloop_la_LIBADD = libshl.la +libeloop_la_CPPFLAGS = $(AM_CPPFLAGS) +libeloop_la_LDFLAGS = $(AM_LDFLAGS) # # libuterm @@ -165,20 +256,16 @@ libtsm_la_LDFLAGS = \ # abstractions and an input layer # -if BUILD_ENABLE_UTERM -lib_LTLIBRARIES += libuterm.la -include_HEADERS += src/uterm.h -pkgconfig_DATA += src/libuterm.pc -endif +noinst_LTLIBRARIES += libuterm.la libuterm_la_SOURCES = \ - $(SHL_DLIST) \ - $(SHL_HOOK) \ - $(SHL_MISC) \ - src/uterm.h \ src/uterm_input.h \ + src/uterm_monitor.h \ src/uterm_video.h \ - src/uterm_pci.h \ + src/uterm_vt.h \ + src/uterm_input_internal.h \ + src/uterm_video_internal.h \ + src/uterm_systemd_internal.h \ src/uterm_video.c \ src/uterm_monitor.c \ src/uterm_vt.c \ @@ -189,47 +276,44 @@ nodist_libuterm_la_SOURCES = libuterm_la_CPPFLAGS = \ $(AM_CPPFLAGS) \ + $(UDEV_CFLAGS) \ $(XKBCOMMON_CFLAGS) -libuterm_la_LIBADD = +libuterm_la_LIBADD = \ + $(UDEV_LIBS) \ $(XKBCOMMON_LIBS) \ - libeloop.la + libeloop.la \ + libshl.la \ + src/uterm_input_fallback.xkb.bin.lo libuterm_la_LDFLAGS = \ - -version-info 1:0:0 + $(AM_LDFLAGS) if BUILD_ENABLE_MULTI_SEAT +libuterm_la_SOURCES += src/uterm_systemd.c libuterm_la_CPPFLAGS += $(SYSTEMD_CFLAGS) libuterm_la_LIBADD += $(SYSTEMD_LIBS) endif -if BUILD_ENABLE_HOTPLUG -libuterm_la_CPPFLAGS += $(UDEV_CFLAGS) -libuterm_la_LIBADD += $(UDEV_LIBS) -endif - -if BUILD_ENABLE_PCIACCESS -libuterm_la_CPPFLAGS += $(PCIACCESS_CFLAGS) -libuterm_la_LIBADD += $(PCIACCESS_LIBS) -libuterm_la_SOURCES += src/uterm_pci.c -endif - if BUILD_ENABLE_VIDEO_FBDEV -libuterm_la_SOURCES += src/uterm_video_fbdev.c +libuterm_la_SOURCES += \ + src/uterm_fbdev_internal.h \ + src/uterm_fbdev_video.c \ + src/uterm_fbdev_render.c endif -if BUILD_ENABLE_VIDEO_DUMB -libuterm_la_SOURCES += src/uterm_video_dumb.c +if BUILD_ENABLE_VIDEO_DRM2D +libuterm_la_SOURCES += \ + src/uterm_drm2d_internal.h \ + src/uterm_drm2d_video.c \ + src/uterm_drm2d_render.c libuterm_la_CPPFLAGS += $(DRM_CFLAGS) libuterm_la_LIBADD += $(DRM_LIBS) endif -if BUILD_ENABLE_VIDEO_DRM +if BUILD_ENABLE_VIDEO_DRM3D libuterm_la_SOURCES += \ - src/uterm_video_drm.c \ - src/static_gl.h \ - src/static_gl_math.c \ - src/static_gl_shader.c -nodist_libuterm_la_SOURCES += \ - src/static_shaders.c + src/uterm_drm3d_internal.h \ + src/uterm_drm3d_video.c \ + src/uterm_drm3d_render.c libuterm_la_CPPFLAGS += \ $(DRM_CFLAGS) \ $(EGL_CFLAGS) \ @@ -239,99 +323,151 @@ libuterm_la_LIBADD += \ $(DRM_LIBS) \ $(EGL_LIBS) \ $(GBM_LIBS) \ - $(GLES2_LIBS) + $(GLES2_LIBS) \ + src/uterm_drm3d_blend.vert.bin.lo \ + src/uterm_drm3d_blend.frag.bin.lo \ + src/uterm_drm3d_blit.vert.bin.lo \ + src/uterm_drm3d_blit.frag.bin.lo \ + src/uterm_drm3d_fill.vert.bin.lo \ + src/uterm_drm3d_fill.frag.bin.lo endif -# -# Shaders -# As there is no need to modify shaders at run-time, we statically compile them -# into object files. As autotools would ignore them, we need to add them to -# EXTRA_DIST. -# The program that converts the shaders into C-source files is "genshader". It's -# pretty simple and just creates a string with the shader source as content. -# - -SHADERS = \ - $(srcdir)/src/static_fill.vert \ - $(srcdir)/src/static_fill.frag \ - $(srcdir)/src/static_blend.vert \ - $(srcdir)/src/static_blend.frag \ - $(srcdir)/src/static_blit.vert \ - $(srcdir)/src/static_blit.frag \ - $(srcdir)/src/static_gltex.vert \ - $(srcdir)/src/static_gltex.frag - -EXTRA_DIST += $(SHADERS) -CLEANFILES += src/static_shaders.c -genshader_SOURCES = src/genshader.c - -src/static_shaders.c: $(SHADERS) genshader$(EXEEXT) - $(AM_V_GEN)./genshader$(EXEEXT) src/static_shaders.c $(SHADERS) +# add shared sources only once +UTERM_DRM_SHARED_SRC = \ + src/uterm_drm_shared_internal.h \ + src/uterm_drm_shared.c +if BUILD_ENABLE_VIDEO_DRM2D +libuterm_la_SOURCES += $(UTERM_DRM_SHARED_SRC) +else +if BUILD_ENABLE_VIDEO_DRM3D +libuterm_la_SOURCES += $(UTERM_DRM_SHARED_SRC) +endif +endif # # Unifont Generator # This generates the unifont sources from raw hex-encoded font data. # -UNIFONT = src/text_font_unifont_data.hex +UNIFONT = $(top_srcdir)/src/font_unifont_data.hex +UNIFONT_BIN = src/font_unifont_data.bin +UNIFONT_LT = src/font_unifont_data.bin.lo EXTRA_DIST += $(UNIFONT) -CLEANFILES += src/text_font_unifont_data.c +CLEANFILES += $(UNIFONT_BIN) genunifont_SOURCES = src/genunifont.c -src/text_font_unifont_data.c: $(UNIFONT) genunifont$(EXEEXT) - $(AM_V_GEN)./genunifont$(EXEEXT) src/text_font_unifont_data.c $(UNIFONT) +genunifont$(BUILD_EXEEXT) $(genunifont_OBJECTS): CC = $(CC_FOR_BUILD) +genunifont$(BUILD_EXEEXT) $(genunifont_OBJECTS): CFLAGS = $(CFLAGS_FOR_BUILD) +genunifont$(BUILD_EXEEXT): LDFLAGS = $(LDFLAGS_FOR_BUILD) + +$(UNIFONT_BIN): $(UNIFONT) genunifont$(BUILD_EXEEXT) + $(AM_V_GEN)./genunifont$(BUILD_EXEEXT) $(UNIFONT_BIN) $(UNIFONT) # -# Text-font library -# The text-font library is used by kmscon _and_ wlterm but is currently linked -# statically as it hasn't been cleaned up entirely. -# It has a build-time dependency to UTERM and runtime dependencies to TSM. +# Kmscon Modules # -if BUILD_ENABLE_KMSCON -noinst_LTLIBRARIES += libtext-font.la -else -if BUILD_ENABLE_WLTERM -noinst_LTLIBRARIES += libtext-font.la -endif +if BUILD_ENABLE_FONT_UNIFONT +module_LTLIBRARIES += mod-unifont.la +noinst_PROGRAMS += genunifont endif -libtext_font_la_SOURCES = \ - $(SHL_DLIST) \ - $(SHL_HASHTABLE) \ - $(SHL_HOOK) \ - src/text.h \ - src/text_font.c -nodist_libtext_font_la_SOURCES = +mod_unifont_la_SOURCES = \ + src/kmscon_module_interface.h \ + src/font_unifont.c \ + src/kmscon_mod_unifont.c +mod_unifont_la_LIBADD = \ + $(UNIFONT_LT) \ + libshl.la +mod_unifont_la_LDFLAGS = \ + $(AM_LDFLAGS) \ + -module \ + -avoid-version -libtext_font_la_CPPFLAGS = \ - $(AM_CPPFLAGS) -libtext_font_la_LIBADD = \ +if BUILD_ENABLE_FONT_PANGO +module_LTLIBRARIES += mod-pango.la +endif + +mod_pango_la_SOURCES = \ + src/kmscon_module_interface.h \ + src/font_pango.c \ + src/kmscon_mod_pango.c +mod_pango_la_CPPFLAGS = \ + $(AM_CPPFLAGS) \ + $(PANGO_CFLAGS) \ + $(TSM_CFLAGS) +mod_pango_la_LIBADD = \ + $(PANGO_LIBS) \ + $(TSM_LIBS) \ -lpthread \ - libtsm.la + libshl.la +mod_pango_la_LDFLAGS = \ + $(AM_LDFLAGS) \ + -module \ + -avoid-version -if BUILD_ENABLE_FONT_8X16 -libtext_font_la_SOURCES += src/text_font_8x16.c +if BUILD_ENABLE_RENDERER_BBULK +module_LTLIBRARIES += mod-bbulk.la endif -if BUILD_ENABLE_FONT_UNIFONT -libtext_font_la_SOURCES += src/text_font_unifont.c -nodist_libtext_font_la_SOURCES += src/text_font_unifont_data.c -endif +mod_bbulk_la_SOURCES = \ + src/kmscon_module_interface.h \ + src/text_bbulk.c \ + src/kmscon_mod_bbulk.c +mod_bbulk_la_CPPFLAGS = \ + $(AM_CPPFLAGS) \ + $(TSM_CFLAGS) +mod_bbulk_la_LIBADD = \ + $(TSM_LIBS) \ + libshl.la +mod_bbulk_la_LDFLAGS = \ + $(AM_LDFLAGS) \ + -module \ + -avoid-version -if BUILD_ENABLE_FONT_FREETYPE2 -libtext_font_la_SOURCES += src/text_font_freetype2.c -libtext_font_la_CPPFLAGS += $(FREETYPE2_CFLAGS) -libtext_font_la_LIBADD += $(FREETYPE2_LIBS) +if BUILD_ENABLE_RENDERER_GLTEX +module_LTLIBRARIES += mod-gltex.la endif -if BUILD_ENABLE_FONT_PANGO -libtext_font_la_SOURCES += src/text_font_pango.c -libtext_font_la_CPPFLAGS += $(PANGO_CFLAGS) -libtext_font_la_LIBADD += $(PANGO_LIBS) +mod_gltex_la_SOURCES = \ + src/kmscon_module_interface.h \ + src/text_gltex.c \ + src/kmscon_mod_gltex.c +mod_gltex_la_CPPFLAGS = \ + $(AM_CPPFLAGS) \ + $(TSM_CFLAGS) \ + $(GLES2_CFLAGS) +mod_gltex_la_LIBADD = \ + $(GLES2_LIBS) \ + $(TSM_LIBS) \ + libshl.la \ + src/text_gltex_atlas.vert.bin.lo \ + src/text_gltex_atlas.frag.bin.lo +mod_gltex_la_LDFLAGS = \ + $(AM_LDFLAGS) \ + -module \ + -avoid-version + +if BUILD_ENABLE_RENDERER_PIXMAN +module_LTLIBRARIES += mod-pixman.la endif +mod_pixman_la_SOURCES = \ + src/kmscon_module_interface.h \ + src/text_pixman.c \ + src/kmscon_mod_pixman.c +mod_pixman_la_CPPFLAGS = \ + $(AM_CPPFLAGS) \ + $(PIXMAN_CFLAGS) +mod_pixman_la_LIBADD = \ + $(PIXMAN_LIBS) \ + libshl.la +mod_pixman_la_LDFLAGS = \ + $(AM_LDFLAGS) \ + -module \ + -avoid-version + # # Binaries # These are the sources for the main binaries and test programs. They mostly @@ -339,34 +475,30 @@ endif # built as part of kmscon. # -if BUILD_ENABLE_KMSCON bin_PROGRAMS += kmscon check_PROGRAMS += \ test_output \ test_vt \ test_input \ test_key -endif +MANPAGES += docs/man/kmscon.1 kmscon_SOURCES = \ - $(SHL_DLIST) \ - $(SHL_MISC) \ - $(SHL_ARRAY) \ - $(SHL_HASHTABLE) \ - $(SHL_RING) \ - $(SHL_TIMER) \ - $(SHL_HOOK) \ src/conf.h \ src/conf.c \ - src/log.h \ - src/log.c \ src/pty.h \ src/pty.c \ + src/font.h \ + src/font.c \ + src/font_8x16.c \ src/text.h \ src/text.c \ + src/text_bblit.c \ + src/kmscon_module_interface.h \ + src/kmscon_module.h \ + src/kmscon_module.c \ src/kmscon_terminal.h \ src/kmscon_dummy.h \ - src/kmscon_compositor.h \ src/kmscon_seat.h \ src/kmscon_seat.c \ src/kmscon_conf.h \ @@ -376,13 +508,19 @@ nodist_kmscon_SOURCES = kmscon_CPPFLAGS = \ $(AM_CPPFLAGS) \ - $(XKBCOMMON_CFLAGS) + $(XKBCOMMON_CFLAGS) \ + $(TSM_CFLAGS) kmscon_LDADD = \ $(XKBCOMMON_LIBS) \ + $(TSM_LIBS) \ libeloop.la \ libuterm.la \ - libtext-font.la \ - -lpthread + libshl.la \ + -lpthread \ + -ldl +kmscon_LDFLAGS = \ + $(AM_LDFLAGS) \ + -rdynamic if BUILD_ENABLE_SESSION_DUMMY kmscon_SOURCES += src/kmscon_dummy.c @@ -390,101 +528,28 @@ endif if BUILD_ENABLE_SESSION_TERMINAL kmscon_SOURCES += src/kmscon_terminal.c -kmscon_LDADD += libtsm.la -endif - -if BUILD_ENABLE_SESSION_CDEV -kmscon_SOURCES += src/kmscon_cdev.c -kmscon_CPPFLAGS += $(FUSE_CFLAGS) -kmscon_LDADD += $(FUSE_LIBS) endif -if BUILD_ENABLE_SESSION_COMPOSITOR -kmscon_SOURCES += src/kmscon_compositor.c -kmscon_CPPFLAGS += $(WAYLAND_CFLAGS) -kmscon_LDADD += $(WAYLAND_LIBS) -endif - -if BUILD_ENABLE_RENDERER_BBLIT -kmscon_SOURCES += src/text_bblit.c -endif - -if BUILD_ENABLE_RENDERER_BBULK -kmscon_SOURCES += src/text_bbulk.c -endif - -if BUILD_ENABLE_RENDERER_GLTEX -kmscon_SOURCES += \ - src/text_gltex.c \ - src/static_gl.h \ - src/static_gl_math.c \ - src/static_gl_shader.c -nodist_kmscon_SOURCES += src/static_shaders.c -kmscon_CPPFLAGS += $(GLES2_CFLAGS) -kmscon_LDADD += $(GLES2_LIBS) -endif - -# -# Wayland Terminal -# - -if BUILD_ENABLE_WLTERM -bin_PROGRAMS += wlterm -endif - -wlterm_SOURCES = \ - $(SHL_MISC) \ - $(SHL_ARRAY) \ - $(SHL_DLIST) \ - $(SHL_HOOK) \ - src/wlt_main.h \ - src/wlt_main.c \ - src/wlt_toolkit.h \ - src/wlt_toolkit.c \ - src/wlt_theme.h \ - src/wlt_theme.c \ - src/wlt_terminal.h \ - src/wlt_terminal.c \ - src/log.h \ - src/log.c \ - src/conf.h \ - src/conf.c \ - src/pty.h \ - src/pty.c -wlterm_CPPFLAGS = \ - $(AM_CPPFLAGS) \ - $(WAYLAND_CFLAGS) \ - $(XKBCOMMON_CFLAGS) -wlterm_LDADD = \ - $(WAYLAND_LIBS) \ - $(XKBCOMMON_LIBS) \ - libeloop.la \ - libtsm.la \ - libtext-font.la \ - -lpthread - # # Tests # test_sources = \ - src/log.h \ - src/log.c \ src/conf.h \ src/conf.c \ tests/test_include.h test_cflags = \ + $(AM_CPPFLAGS) \ $(XKBCOMMON_CFLAGS) test_libs = \ $(XKBCOMMON_LIBS) \ - libeloop.la + libeloop.la \ + libshl.la test_output_SOURCES = \ $(test_sources) \ tests/test_output.c -test_output_CPPFLAGS = \ - $(AM_CPPFLAGS) \ - $(test_cflags) +test_output_CPPFLAGS = $(test_cflags) test_output_LDADD = \ $(test_libs) \ libuterm.la @@ -492,9 +557,7 @@ test_output_LDADD = \ test_vt_SOURCES = \ $(test_sources) \ tests/test_vt.c -test_vt_CPPFLAGS = \ - $(AM_CPPFLAGS) \ - $(test_cflags) +test_vt_CPPFLAGS = $(test_cflags) test_vt_LDADD = \ $(test_libs) \ libuterm.la @@ -502,9 +565,7 @@ test_vt_LDADD = \ test_input_SOURCES = \ $(test_sources) \ tests/test_input.c -test_input_CPPFLAGS = \ - $(AM_CPPFLAGS) \ - $(test_cflags) +test_input_CPPFLAGS = $(test_cflags) test_input_LDADD = \ $(test_libs) \ libuterm.la @@ -512,8 +573,65 @@ test_input_LDADD = \ test_key_SOURCES = \ $(test_sources) \ tests/test_key.c -test_key_CPPFLAGS = \ - $(AM_CPPFLAGS) \ - $(test_cflags) -test_key_LDADD = \ - $(test_libs) +test_key_CPPFLAGS = $(test_cflags) +test_key_LDADD = $(test_libs) + +# +# Manpages +# + +man_MANS = +EXTRA_DIST += ${patsubst %.1,%.xml,${patsubst %.3,%.xml,${patsubst %.5,%.xml,${patsubst %.7,%.xml,$(MANPAGES)}}}} +CLEANFILES += $(MANPAGES) $(MANPAGES_ALIASES) .man_fixup + +if BUILD_HAVE_XSLTPROC +if BUILD_HAVE_MANPAGES_STYLESHEET + +man_MANS += $(MANPAGES) $(MANPAGES_ALIASES) + +XSLTPROC_FLAGS = \ + --stringparam man.authors.section.enabled 0 \ + --stringparam man.copyright.section.enabled 0 \ + --stringparam funcsynopsis.style ansi \ + --stringparam man.output.quietly 1 \ + --nonet + +XSLTPROC_PROCESS_MAN = \ + $(AM_V_GEN)$(MKDIR_P) $(dir $@) && \ + $(XSLTPROC) -o "$@" $(XSLTPROC_FLAGS) $(BUILD_MANPAGES_STYLESHEET) "$<" && \ + touch .man_fixup + +# Force .man_fixup if $(MANPAGES) are not built +.man_fixup: | $(MANPAGES) + @touch .man_fixup + +$(MANPAGES_ALIASES): $(MANPAGES) .man_fixup + $(AM_V_GEN)if test -n "$@" ; then $(SED) -i -e 's/^\.so \([a-z_]\+\)\.\([0-9]\)$$/\.so man\2\/\1\.\2/' "$@" ; fi + +docs/man/%.1: docs/man/%.xml + $(XSLTPROC_PROCESS_MAN) + +docs/man/%.3: docs/man/%.xml + $(XSLTPROC_PROCESS_MAN) + +docs/man/%.5: docs/man/%.xml + $(XSLTPROC_PROCESS_MAN) + +docs/man/%.7: docs/man/%.xml + $(XSLTPROC_PROCESS_MAN) + +endif # BUILD_HAVE_MANPAGES_STYLESHEET +endif # BUILD_HAVE_XSLTPROC + +# +# Phony targets +# + +.PHONY: $(TPHONY) + +# +# Empty .SECONDARY target causes alle intermediate files to be treated as +# secondary files. That is, they don't get deleted after make finished. +# + +.SECONDARY: