The code generation rules are explicitly built for each supported API target, but they ought to be refactored since they are pretty much identical. In order to do that, we can store the arguments to the custom_target rules inside an array and then iterate over each element. This cuts down the complexity of the Meson build, and the chances of getting something wrong due to duplication.macos/v1.5.9
parent
d6c4784401
commit
3eaddbef62
@ -1,82 +1,42 @@ |
|||||||
headers = [ 'common.h' ] |
headers = [ 'common.h' ] |
||||||
|
|
||||||
gl_generated = custom_target('gl_generated.h', |
# GL is always generated |
||||||
input: gl_registry, |
generated_headers = [ [ 'gl.h', 'gl_generated.h', gl_registry ] ] |
||||||
output: [ |
|
||||||
'gl_generated.h', |
|
||||||
], |
|
||||||
command: [ |
|
||||||
python, |
|
||||||
gen_dispatch_py, |
|
||||||
'--header', |
|
||||||
'--no-source', |
|
||||||
'--outputdir=@OUTDIR@', |
|
||||||
'@INPUT@' |
|
||||||
], |
|
||||||
install: true, |
|
||||||
install_dir: join_paths(epoxy_includedir, 'epoxy')) |
|
||||||
|
|
||||||
gen_headers = [ gl_generated ] |
|
||||||
headers += [ 'gl.h', ] |
|
||||||
|
|
||||||
if build_egl |
if build_egl |
||||||
egl_generated = custom_target('egl_generated.h', |
generated_headers += [ [ 'egl.h', 'egl_generated.h', egl_registry ] ] |
||||||
input: egl_registry, |
|
||||||
output: [ |
|
||||||
'egl_generated.h', |
|
||||||
], |
|
||||||
command: [ |
|
||||||
python, |
|
||||||
gen_dispatch_py, |
|
||||||
'--header', |
|
||||||
'--no-source', |
|
||||||
'--outputdir=@OUTDIR@', |
|
||||||
'@INPUT@' |
|
||||||
], |
|
||||||
install: true, |
|
||||||
install_dir: join_paths(epoxy_includedir, 'epoxy')) |
|
||||||
gen_headers += [ egl_generated ] |
|
||||||
headers += [ 'egl.h' ] |
|
||||||
endif |
endif |
||||||
|
|
||||||
if build_glx |
if build_glx |
||||||
glx_generated = custom_target('glx_generated.h', |
generated_headers += [ [ 'glx.h', 'glx_generated.h', glx_registry ] ] |
||||||
input: glx_registry, |
|
||||||
output: [ |
|
||||||
'glx_generated.h', |
|
||||||
], |
|
||||||
command: [ |
|
||||||
python, |
|
||||||
gen_dispatch_py, |
|
||||||
'--header', |
|
||||||
'--no-source', |
|
||||||
'--outputdir=@OUTDIR@', |
|
||||||
'@INPUT@' |
|
||||||
], |
|
||||||
install: true, |
|
||||||
install_dir: join_paths(epoxy_includedir, 'epoxy')) |
|
||||||
gen_headers += [ glx_generated ] |
|
||||||
headers += [ 'glx.h' ] |
|
||||||
endif |
endif |
||||||
|
|
||||||
if build_wgl |
if build_wgl |
||||||
wgl_generated = custom_target('wgl_generated.h', |
generated_headers += [ [ 'wgl.h', 'wgl_generated.h', wgl_registry ] ] |
||||||
input: wgl_registry, |
|
||||||
output: [ |
|
||||||
'wgl_generated.h', |
|
||||||
], |
|
||||||
command: [ |
|
||||||
python, |
|
||||||
gen_dispatch_py, |
|
||||||
'--header', |
|
||||||
'--no-source', |
|
||||||
'--outputdir=@OUTDIR@', |
|
||||||
'@INPUT@' |
|
||||||
], |
|
||||||
install: true, |
|
||||||
install_dir: join_paths(epoxy_includedir, 'epoxy')) |
|
||||||
gen_headers += [ wgl_generated ] |
|
||||||
headers += [ 'wgl.h' ] |
|
||||||
endif |
endif |
||||||
|
|
||||||
|
gen_headers = [] |
||||||
|
|
||||||
|
foreach g: generated_headers |
||||||
|
header = g[0] |
||||||
|
gen_header = g[1] |
||||||
|
registry = g[2] |
||||||
|
generated = custom_target(gen_header, |
||||||
|
input: registry, |
||||||
|
output: [ gen_header ], |
||||||
|
command: [ |
||||||
|
python, |
||||||
|
gen_dispatch_py, |
||||||
|
'--header', |
||||||
|
'--no-source', |
||||||
|
'--outputdir=@OUTDIR@', |
||||||
|
'@INPUT@', |
||||||
|
], |
||||||
|
install: true, |
||||||
|
install_dir: join_paths(epoxy_includedir, 'epoxy')) |
||||||
|
|
||||||
|
gen_headers += [ generated ] |
||||||
|
headers += [ header ] |
||||||
|
endforeach |
||||||
|
|
||||||
install_headers(headers, subdir: 'epoxy') |
install_headers(headers, subdir: 'epoxy') |
||||||
|
Loading…
Reference in new issue