summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEmmanuele Bassi <ebassi@gnome.org>2017-04-26 16:02:17 +0100
committerEmmanuele Bassi <ebassi@gnome.org>2017-05-03 15:10:57 +0100
commit6728f45aa06c70503ef93d71c3e228381d939ac2 (patch)
tree45c97ec96d236a6fea7173593c72929510404387
parentc1965150c72cc11d51febd4fec0e4334601f947c (diff)
downloadgtk+-6728f45aa06c70503ef93d71c3e228381d939ac2.tar.gz
build: Ensure that Vulkan shaders are rebuilt if glslc is found
If glslc is found, rebuild the shaders from GLSL to SPIR-V; otherwise, we're just going to use the built files we have committed in the source repository.
-rw-r--r--gsk/meson.build91
1 files changed, 51 insertions, 40 deletions
diff --git a/gsk/meson.build b/gsk/meson.build
index 6fc681b5e5..d6a9aa150b 100644
--- a/gsk/meson.build
+++ b/gsk/meson.build
@@ -40,7 +40,7 @@ gsk_public_headers = files([
'gsktypes.h',
])
-install_headers(gsk_public_headers, 'gsk.h', subdir : 'gtk-4.0/gsk')
+install_headers(gsk_public_headers, 'gsk.h', subdir: 'gtk-4.0/gsk')
gsk_private_vulkan_shaders = []
gsk_private_vulkan_compiled_shaders = []
@@ -97,53 +97,61 @@ if have_vulkan
gsk_private_vulkan_shaders += gsk_private_vulkan_fragment_shaders
gsk_private_vulkan_shaders += gsk_private_vulkan_vertex_shaders
- foreach shader : gsk_private_vulkan_shaders
+ glslc = find_program('glslc', required: false)
+ foreach shader: gsk_private_vulkan_shaders
basefn = shader.split('.').get(0)
suffix = shader.split('.').get(1)
- # FIXME: the compiled shaders seem to exist in the srcdir already, do we
- # want to or need to add a target to create them with glslc? Do we need to
- # check for glslc at all then?
- #
- # stage_arg = suffix == 'frag' ? '-fshader-stage=fragment' : '-fshader-stage=vertex'
- # compiled_shader = custom_target('xyz', input : shader,
- # output : '@0@.@1@.spv'.format(basefn, suffix),
- # command: [glslc, stage_arg, '-DCLIP_NONE', '-o', '@OUTPUT@'])
-
- gsk_private_vulkan_compiled_shaders += '@0@.@1@.spv'.format(basefn, suffix)
+ stage_arg = suffix == 'frag' ? '-fshader-stage=fragment' : '-fshader-stage=vertex'
+ spv_shader = '@0@.@1@.spv'.format(basefn, suffix)
+
+ if glslc.found()
+ compiled_shader = custom_target(spv_shader,
+ input: shader,
+ output: spv_shader,
+ command: [
+ glslc,
+ stage_arg,
+ '-DCLIP_NONE',
+ '-o', '@OUTPUT@'
+ ])
+ endif
+ gsk_private_vulkan_compiled_shaders += spv_shader
gsk_private_vulkan_compiled_shaders += '@0@-clip.@1@.spv'.format(basefn, suffix)
gsk_private_vulkan_compiled_shaders += '@0@-clip-rounded.@1@.spv'.format(basefn, suffix)
endforeach
endif # have_vulkan
-gsk_resources_xml = configure_file(output : 'gsk.resources.xml',
- input : 'gen-gsk-gresources-xml.py',
- command : [find_program('gen-gsk-gresources-xml.py'),
- '@OUTPUT@',
- gsk_private_source_shaders,
- gsk_private_vulkan_compiled_shaders,
- gsk_private_vulkan_shaders])
+gsk_resources_xml = configure_file(output: 'gsk.resources.xml',
+ input: 'gen-gsk-gresources-xml.py',
+ command: [
+ find_program('gen-gsk-gresources-xml.py'),
+ '@OUTPUT@',
+ gsk_private_source_shaders,
+ gsk_private_vulkan_compiled_shaders,
+ gsk_private_vulkan_shaders
+ ])
# FIXME: do we need this variable?
gsk_sources = gsk_public_sources + gsk_private_sources
gsk_enums = gnome.mkenums('gskenumtypes',
- sources: gsk_public_headers,
- c_template : 'gskenumtypes.c.template',
- h_template : 'gskenumtypes.h.template',
- install_dir : 'include/gtk-4.0/gsk',
- install_header : true)
+ sources: gsk_public_headers,
+ c_template: 'gskenumtypes.c.template',
+ h_template: 'gskenumtypes.h.template',
+ install_dir: join_paths(gtk_includedir, 'gtk-4.0/gsk'),
+ install_header: true)
gskenum_h = gsk_enums[1]
gskresources = gnome.compile_resources('gskresources',
- gsk_resources_xml,
- source_dir: '.',
- c_name: '_gsk',
- extra_args: '--manual-register')
+ gsk_resources_xml,
+ source_dir: '.',
+ c_name: '_gsk',
+ extra_args: [ '--manual-register', ])
-gsk_gen_headers = [gskenum_h]
+gsk_gen_headers = [ gskenum_h, ]
gsk_deps = [
graphene_dep,
@@ -154,18 +162,21 @@ gsk_deps = [
]
libgsk = static_library('gsk',
- sources: [gsk_sources, gsk_enums, gskresources],
- dependencies: gsk_deps,
- include_directories: [confinc],
- c_args: ['-DGSK_COMPILATION', '-DG_LOG_DOMAIN="Gsk"'] + common_cflags,
- link_with: libgdk,
- link_args: common_ldflags)
+ sources: [ gsk_sources, gsk_enums, gskresources, ],
+ dependencies: gsk_deps,
+ include_directories: [ confinc, ],
+ c_args: [
+ '-DGSK_COMPILATION',
+ '-DG_LOG_DOMAIN="Gsk"',
+ '-DG_LOG_STRUCTURED=1',
+ ] + common_cflags,
+ link_with: libgdk,
+ link_args: common_ldflags)
# We don't have link_with: to internal static libs here on purpose, just
# list the dependencies and generated headers and such, for use in the
# "public" libgtk_dep used by internal executables.
-libgsk_dep = declare_dependency(
- depends: gsk_sources,
- include_directories: [confinc],
- sources: [gskenum_h, gskresources],
- dependencies: libgdk_dep)
+libgsk_dep = declare_dependency(depends: gsk_sources,
+ include_directories: [ confinc, ],
+ sources: [ gskenum_h, gskresources, ],
+ dependencies: libgdk_dep)