From 46d2f1f08d8919155ae6455ae2c3a17b262a63f7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jan=20Ekstr=C3=B6m?= Date: Sun, 15 Apr 2018 03:16:36 +0300 Subject: build: fixup vendored wayland protocols with variants Utilize the SRC variable for this to get a built-in relative path. Can be tested by adding `--variant="random_string"` to configure and build. --- waftools/generators/sources.py | 27 +++++++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) (limited to 'waftools/generators') diff --git a/waftools/generators/sources.py b/waftools/generators/sources.py index 0b83432bc1..5bde478a34 100644 --- a/waftools/generators/sources.py +++ b/waftools/generators/sources.py @@ -9,8 +9,11 @@ def __zshcomp_cmd__(ctx, argument): return '"${{BIN_PERL}}" "{0}/TOOLS/zsh.pl" "{1}" > "${{TGT}}"' \ .format(ctx.srcnode.abspath(), argument) -def __wayland_scanner_cmd__(ctx, mode, dir, src): - return "${{WAYSCAN}} {0} < {1}/{2} > ${{TGT}}".format(mode, dir, src) +def __wayland_scanner_cmd__(ctx, mode, dir, src, vendored_file): + return "${{WAYSCAN}} {0} < {1} > ${{TGT}}".format( + mode, + "${SRC}" if vendored_file else "{}/{}".format(dir, src) + ) def __file2string__(ctx, **kwargs): ctx( @@ -55,17 +58,33 @@ def __zshcomp__(ctx, **kwargs): ) def __wayland_protocol_code__(ctx, **kwargs): + protocol_is_vendored = kwargs.get("vendored_protocol", False) + file_name = kwargs['protocol'] + '.xml' + + if protocol_is_vendored: + del kwargs['vendored_protocol'] + kwargs['source'] = '{}/{}'.format(kwargs['proto_dir'], file_name) + ctx( rule = __wayland_scanner_cmd__(ctx, 'code', kwargs['proto_dir'], - kwargs['protocol'] + '.xml'), + file_name, + protocol_is_vendored), name = os.path.basename(kwargs['target']), **kwargs ) def __wayland_protocol_header__(ctx, **kwargs): + protocol_is_vendored = kwargs.get("vendored_protocol", False) + file_name = kwargs['protocol'] + '.xml' + + if protocol_is_vendored: + del kwargs['vendored_protocol'] + kwargs['source'] = '{}/{}'.format(kwargs['proto_dir'], file_name) + ctx( rule = __wayland_scanner_cmd__(ctx, 'client-header', kwargs['proto_dir'], - kwargs['protocol'] + '.xml'), + file_name, + protocol_is_vendored), before = ('c',), name = os.path.basename(kwargs['target']), **kwargs -- cgit v1.2.3