diff options
Diffstat (limited to 'meson/test cases/common/90 gen extra')
-rw-r--r-- | meson/test cases/common/90 gen extra/meson.build | 40 | ||||
-rw-r--r-- | meson/test cases/common/90 gen extra/name.dat | 1 | ||||
-rw-r--r-- | meson/test cases/common/90 gen extra/name.l | 3 | ||||
-rw-r--r-- | meson/test cases/common/90 gen extra/plain.c | 5 | ||||
-rwxr-xr-x | meson/test cases/common/90 gen extra/srcgen.py | 27 | ||||
-rw-r--r-- | meson/test cases/common/90 gen extra/srcgen2.py | 32 | ||||
-rw-r--r-- | meson/test cases/common/90 gen extra/srcgen3.py | 15 | ||||
-rw-r--r-- | meson/test cases/common/90 gen extra/upper.c | 5 |
8 files changed, 128 insertions, 0 deletions
diff --git a/meson/test cases/common/90 gen extra/meson.build b/meson/test cases/common/90 gen extra/meson.build new file mode 100644 index 000000000..cbbdceb2e --- /dev/null +++ b/meson/test cases/common/90 gen extra/meson.build @@ -0,0 +1,40 @@ +project('extra args in gen', 'c') + +prog = find_program('srcgen.py') + +gen = generator(prog, + output : '@BASENAME@.c', + arguments : ['--input=@INPUT@', '--output=@OUTPUT@', '@EXTRA_ARGS@']) + +g1 = gen.process('name.dat') +g2 = gen.process('name.dat', extra_args: '--upper') + +test('basic', executable('basic', 'plain.c', g1)) +test('upper', executable('upper', 'upper.c', g2)) + +prog2 = find_program('srcgen2.py') +basename_gen = generator(prog2, + output : ['@BASENAME@.tab.c', '@BASENAME@.tab.h'], + arguments : ['@BUILD_DIR@', '@BASENAME@', '@INPUT@']) + +basename_src = basename_gen.process('name.l') + +test('basename', executable('basename', basename_src)) + +plainname_gen = generator(prog2, + output : ['@PLAINNAME@.tab.c', '@PLAINNAME@.tab.h'], + arguments : ['@BUILD_DIR@', '@PLAINNAME@', '@INPUT@']) + +plainname_src = plainname_gen.process('name.l') + +test('plainname', executable('plainname', plainname_src)) + +prog3 = find_program('srcgen3.py') +capture_gen = generator(prog3, + output : ['@BASENAME@.yy.c'], + arguments : ['@INPUT@'], + capture : true) + +capture_src = capture_gen.process('name.l') + +test('capture', executable('capture', capture_src)) diff --git a/meson/test cases/common/90 gen extra/name.dat b/meson/test cases/common/90 gen extra/name.dat new file mode 100644 index 000000000..caf5b1caf --- /dev/null +++ b/meson/test cases/common/90 gen extra/name.dat @@ -0,0 +1 @@ +bob_mcbob diff --git a/meson/test cases/common/90 gen extra/name.l b/meson/test cases/common/90 gen extra/name.l new file mode 100644 index 000000000..c4ba277d2 --- /dev/null +++ b/meson/test cases/common/90 gen extra/name.l @@ -0,0 +1,3 @@ +int main(void) { +return 0; +} diff --git a/meson/test cases/common/90 gen extra/plain.c b/meson/test cases/common/90 gen extra/plain.c new file mode 100644 index 000000000..c068a023e --- /dev/null +++ b/meson/test cases/common/90 gen extra/plain.c @@ -0,0 +1,5 @@ +int bob_mcbob(void); + +int main(void) { + return bob_mcbob(); +} diff --git a/meson/test cases/common/90 gen extra/srcgen.py b/meson/test cases/common/90 gen extra/srcgen.py new file mode 100755 index 000000000..c64f54000 --- /dev/null +++ b/meson/test cases/common/90 gen extra/srcgen.py @@ -0,0 +1,27 @@ +#!/usr/bin/env python3 + +import sys +import argparse + +parser = argparse.ArgumentParser() +parser.add_argument('--input', dest='input', + help='the input file') +parser.add_argument('--output', dest='output', + help='the output file') +parser.add_argument('--upper', dest='upper', action='store_true', default=False, + help='Convert to upper case.') + +c_templ = '''int %s(void) { + return 0; +} +''' + +options = parser.parse_args(sys.argv[1:]) + +with open(options.input) as f: + funcname = f.readline().strip() +if options.upper: + funcname = funcname.upper() + +with open(options.output, 'w') as f: + f.write(c_templ % funcname) diff --git a/meson/test cases/common/90 gen extra/srcgen2.py b/meson/test cases/common/90 gen extra/srcgen2.py new file mode 100644 index 000000000..9cdf12d59 --- /dev/null +++ b/meson/test cases/common/90 gen extra/srcgen2.py @@ -0,0 +1,32 @@ +#!/usr/bin/env python3 + +import os +import sys +import argparse + +parser = argparse.ArgumentParser() +parser.add_argument('target_dir', + help='the target dir') +parser.add_argument('stem', + help='the stem') +parser.add_argument('input', + help='the input file') + +options = parser.parse_args(sys.argv[1:]) + +with open(options.input) as f: + content = f.read() + + +output_c = os.path.join(options.target_dir, options.stem + ".tab.c") +with open(output_c, 'w') as f: + f.write(content) + + +output_h = os.path.join(options.target_dir, options.stem + ".tab.h") +h_content = '''#pragma once + +int myfun(void); +''' +with open(output_h, 'w') as f: + f.write(h_content) diff --git a/meson/test cases/common/90 gen extra/srcgen3.py b/meson/test cases/common/90 gen extra/srcgen3.py new file mode 100644 index 000000000..b7371143a --- /dev/null +++ b/meson/test cases/common/90 gen extra/srcgen3.py @@ -0,0 +1,15 @@ +#!/usr/bin/env python3 + +import sys +import argparse + +parser = argparse.ArgumentParser() +parser.add_argument('input', + help='the input file') + +options = parser.parse_args(sys.argv[1:]) + +with open(options.input) as f: + content = f.read().strip() + +print(content) diff --git a/meson/test cases/common/90 gen extra/upper.c b/meson/test cases/common/90 gen extra/upper.c new file mode 100644 index 000000000..82c32529e --- /dev/null +++ b/meson/test cases/common/90 gen extra/upper.c @@ -0,0 +1,5 @@ +int BOB_MCBOB(void); + +int main(void) { + return BOB_MCBOB(); +} |