summaryrefslogtreecommitdiff
path: root/meson.build
diff options
context:
space:
mode:
authorPřemysl Eric Janouch <p@janouch.name>2022-08-10 18:11:05 +0200
committerPřemysl Eric Janouch <p@janouch.name>2022-08-11 00:19:59 +0200
commitcf19f8287547c523f65879b9e9477950c81a9eed (patch)
treec6be8ae4f6e0b24da953633d5cae77c8b91e5cb1 /meson.build
parent9c9453172a3941b6e43ceac0f86ecd96ead1ffb2 (diff)
downloadfiv-cf19f8287547c523f65879b9e9477950c81a9eed.tar.gz
fiv-cf19f8287547c523f65879b9e9477950c81a9eed.tar.xz
fiv-cf19f8287547c523f65879b9e9477950c81a9eed.zip
Automate Windows builds, add icons to executables
Scripts have been ported from sdtui, and adjusted for Meson. The port is broken through and through on WINE, but sort-of works natively.
Diffstat (limited to 'meson.build')
-rw-r--r--meson.build47
1 files changed, 42 insertions, 5 deletions
diff --git a/meson.build b/meson.build
index 9c40889..d646a2a 100644
--- a/meson.build
+++ b/meson.build
@@ -91,8 +91,32 @@ configure_file(
configuration : conf,
)
+rc = []
+if host_machine.system() == 'windows'
+ windows = import('windows')
+ rsvg_convert = find_program('rsvg-convert')
+ icotool = find_program('icotool')
+
+ # Meson is brain-dead and retarded, so these PNGs cannot be installed,
+ # only because they must all have the same name when installed.
+ # The largest size is mainly for an appropriately sized Windows icon.
+ icon_png_list = []
+ foreach size : ['16', '32', '48', '256']
+ icon_dimensions = size + 'x' + size
+ icon_png_list += custom_target(icon_dimensions + ' icon',
+ input : 'fiv.svg',
+ output : 'fiv.' + icon_dimensions + '.png',
+ command : [rsvg_convert, '--output', '@OUTPUT@',
+ '--width', size, '--height', size, '@INPUT@'])
+ endforeach
+
+ icon_ico = custom_target(input : icon_png_list, output : 'fiv.ico',
+ command : [icotool, '-c', '-o', '@OUTPUT@', '@INPUT@'])
+ rc += windows.compile_resources('fiv.rc', depends : icon_ico)
+endif
+
gnome = import('gnome')
-resources = gnome.compile_resources('resources',
+gresources = gnome.compile_resources('resources',
'resources/resources.gresource.xml',
source_dir : 'resources',
c_name : 'resources',
@@ -108,9 +132,11 @@ tiff_tables = custom_target('tiff-tables.h',
desktops = ['fiv.desktop', 'fiv-browse.desktop']
exe = executable('fiv', 'fiv.c', 'fiv-view.c', 'fiv-io.c', 'fiv-context-menu.c',
'fiv-browser.c', 'fiv-sidebar.c', 'fiv-thumbnail.c', 'fiv-collection.c',
- 'xdg.c', resources,
+ 'xdg.c', gresources, rc,
install : true,
- dependencies : dependencies)
+ dependencies : dependencies,
+ win_subsystem : 'windows',
+)
if gdkpixbuf.found()
executable('io-benchmark', 'fiv-io-benchmark.c', 'fiv-io.c', 'xdg.c',
build_by_default : false,
@@ -118,12 +144,14 @@ if gdkpixbuf.found()
endif
desktops += 'fiv-jpegcrop.desktop'
-jpegcrop = executable('fiv-jpegcrop', 'fiv-jpegcrop.c',
+jpegcrop = executable('fiv-jpegcrop', 'fiv-jpegcrop.c', rc,
install : true,
dependencies : [
dependency('gtk+-3.0'),
dependency('libturbojpeg'),
- ])
+ ],
+ win_subsystem : 'windows',
+)
if get_option('tools').enabled()
# libjq 1.6 lacks a pkg-config file, and there is no release in sight.
@@ -170,6 +198,15 @@ if host_machine.system() != 'windows'
if not meson.is_cross_build()
meson.add_install_script(updater, skip_if_destdir : dynamic_desktops)
endif
+elif meson.is_cross_build()
+ msys2_root = meson.get_external_property('msys2_root')
+ meson.add_install_script('msys2-cross-install.sh', msys2_root)
+
+ # This is the minimum to run targets from msys2-cross-configure.sh builds.
+ meson.add_devenv({
+ 'WINEPATH' : msys2_root / 'bin',
+ 'XDG_DATA_DIRS' : msys2_root / 'share',
+ })
endif
install_data('fiv.svg',