summaryrefslogtreecommitdiff
path: root/pkg/wld/gen.lua
diff options
context:
space:
mode:
Diffstat (limited to 'pkg/wld/gen.lua')
-rw-r--r--pkg/wld/gen.lua68
1 files changed, 68 insertions, 0 deletions
diff --git a/pkg/wld/gen.lua b/pkg/wld/gen.lua
new file mode 100644
index 00000000..b79ba516
--- /dev/null
+++ b/pkg/wld/gen.lua
@@ -0,0 +1,68 @@
+cflags{
+ '-D WITH_WAYLAND_SHM',
+ '-D WITH_WAYLAND_DRM',
+ '-I $outdir',
+ '-I pkg/fontconfig/src',
+ '-I pkg/freetype/src/include',
+ '-I pkg/libdrm/src',
+ '-I pkg/libdrm/src/include/drm',
+ '-I $builddir/pkg/pixman/include',
+ '-I $builddir/pkg/wayland/include',
+}
+
+pkg.hdrs = copy('$outdir/include/wld', '$srcdir', {'drm.h', 'pixman.h', 'wayland.h', 'wld.h'})
+pkg.hdrs.install = true
+
+local srcs = {
+ 'buffer.c',
+ 'buffered_surface.c',
+ 'color.c',
+ 'context.c',
+ 'drm.c',
+ 'dumb.c',
+ 'font.c',
+ 'renderer.c',
+ 'surface.c',
+ 'pixman.c',
+ 'wayland.c',
+ 'wayland-shm.c',
+ 'wayland-drm.c',
+ 'wayland-drm-protocol.c.o',
+}
+local libs = {
+ 'fontconfig/libfontconfig.a.d',
+ 'freetype/libfreetype.a.d',
+ 'libdrm/libdrm.a',
+ 'pixman/libpixman.a',
+ 'wayland/libwayland-client.a.d',
+}
+
+if config.video_drivers and config.video_drivers['intel'] then
+ cflags{'-D WITH_DRM_INTEL', '-I pkg/libdrm/src/intel'}
+ table.insert(srcs, {'intel.c', 'intel/batch.c'})
+ table.insert(libs, 'libdrm/libdrm_intel.a.d')
+end
+if config.video_drivers and config.video_drivers['nouveau'] then
+ cflags{'-D WITH_DRM_NOUVEAU', '-I pkg/libdrm/src/nouveau'}
+ table.insert(srcs, 'nouveau.c')
+ table.insert(libs, 'libdrm/libdrm_nouveau.a')
+end
+
+waylandproto('protocol/wayland-drm.xml',
+ 'protocol/wayland-drm-client-protocol.h',
+ 'protocol/wayland-drm-server-protocol.h',
+ 'wayland-drm-protocol.c'
+)
+
+pkg.deps = {
+ '$builddir/pkg/fontconfig/fetch.stamp',
+ '$builddir/pkg/freetype/fetch.stamp',
+ '$builddir/pkg/libdrm/fetch.stamp',
+ '$outdir/protocol/wayland-drm-client-protocol.h',
+ 'pkg/pixman/headers',
+ 'pkg/wayland/headers',
+}
+
+lib('libwld.a', {srcs, expand{'$builddir/pkg/', libs}})
+
+fetch 'git'