[Piglit] [PATCH 4/4] gen_variable_index_read_tests.py: reduce duplication with loop
Dylan Baker
baker.dylan.c at gmail.com
Mon Apr 13 16:18:22 PDT 2015
This reduces the number of calls to make_{fs,vs} by using more loops.
This means less code and makes some things easier to read and
understand.
Signed-off-by: Dylan Baker <dylanx.c.baker at intel.com>
---
generated_tests/gen_variable_index_read_tests.py | 128 +++++++----------------
1 file changed, 39 insertions(+), 89 deletions(-)
diff --git a/generated_tests/gen_variable_index_read_tests.py b/generated_tests/gen_variable_index_read_tests.py
index 7c597cb..f28087b 100644
--- a/generated_tests/gen_variable_index_read_tests.py
+++ b/generated_tests/gen_variable_index_read_tests.py
@@ -165,96 +165,46 @@ def main():
array_dims = [0, 3]
matrix_dims = [2, 3, 4]
glsl_versions = [110, 120]
- iter_ = itertools.product(modes, array_dims, matrix_dims, glsl_versions)
- for mode, array_dim, matrix_dim, glsl_version in iter_:
- if array_dim != 0:
- arr = 'array-'
- idx_text = 'index-'
-
- # TODO: This can certainly be rolled up into a loop
-
- make_fs(
- 'fs-{mode}-{arr}mat{matrix_dim}-col-row-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 1, 'col', 'float',
- glsl_version))
-
- make_fs(
- 'fs-{mode}-{arr}mat{matrix_dim}-row-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 1, 1, 'float',
- glsl_version))
-
- make_fs(
- 'fs-{mode}-{arr}mat{matrix_dim}-col-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 1, 'col',
- 'vec{}'.format(matrix_dim), glsl_version))
-
- make_fs(
- 'fs-{mode}-{arr}mat{matrix_dim}-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 1, 1,
- 'vec{}'.format(matrix_dim), glsl_version))
-
- make_vs(
- 'vs-{mode}-{arr}mat{matrix_dim}-col-row-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 1, 'col', 'float',
- glsl_version))
-
- make_vs(
- 'vs-{mode}-{arr}mat{matrix_dim}-row-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 1, 1, 'float',
- glsl_version))
-
- make_vs(
- 'vs-{mode}-{arr}mat{matrix_dim}-col-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 1, 'col',
- 'vec{}'.format(matrix_dim), glsl_version))
-
- make_vs(
- 'vs-{mode}-{arr}mat{matrix_dim}-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 1, 1,
- 'vec{}'.format(matrix_dim), glsl_version))
+ cols = [1, 'col']
+ stages = ['fs', 'vs']
+ iter_ = itertools.product(stages, modes, array_dims, matrix_dims,
+ glsl_versions, cols)
+ for stage, mode, array_dim, matrix_dim, glsl_version, col in iter_:
+ if stage == 'vs':
+ func = make_vs
else:
- arr = ''
- idx_text = ''
-
- make_fs(
- 'fs-{mode}-{arr}mat{matrix_dim}-{idx_text}col-row-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 'index', 'col', 'float',
- glsl_version))
-
- make_fs(
- 'fs-{mode}-{arr}mat{matrix_dim}-{idx_text}row-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 'index', 1, 'float',
- glsl_version))
-
- make_fs(
- 'fs-{mode}-{arr}mat{matrix_dim}-{idx_text}col-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 'index', 'col',
- 'vec{}'.format(matrix_dim), glsl_version))
-
- make_fs(
- 'fs-{mode}-{arr}mat{matrix_dim}-{idx_text}rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 'index', 1,
- 'vec{}'.format(matrix_dim), glsl_version))
-
- make_vs(
- 'vs-{mode}-{arr}mat{matrix_dim}-{idx_text}col-row-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 'index', 'col', 'float',
- glsl_version))
-
- make_vs(
- 'vs-{mode}-{arr}mat{matrix_dim}-{idx_text}row-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 'index', 1, 'float',
- glsl_version))
-
- make_vs(
- 'vs-{mode}-{arr}mat{matrix_dim}-{idx_text}col-rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 'index', 'col',
- 'vec{}'.format(matrix_dim), glsl_version))
-
- make_vs(
- 'vs-{mode}-{arr}mat{matrix_dim}-{idx_text}rd.shader_test'.format(**locals()),
- TestParams(matrix_dim, array_dim, mode, 'index', 1,
- 'vec{}'.format(matrix_dim), glsl_version))
+ func = make_fs
+
+ for expect in ['float', 'vec{}'.format(matrix_dim)]:
+ if array_dim != 0:
+ arr = 'array-'
+ idx_text = 'index-'
+
+ func(
+ '{stage}-{mode}-{arr}mat{matrix_dim}-{col}{row}rd.shader_test'.format(
+ stage=stage,
+ mode=mode,
+ arr=arr,
+ matrix_dim=matrix_dim,
+ col='col-' if col == 'col' else '',
+ row='row-' if expect == 'float' else ''),
+ TestParams(matrix_dim, array_dim, mode, 1, col, expect,
+ glsl_version))
+ else:
+ arr = ''
+ idx_text = ''
+
+ func(
+ '{stage}-{mode}-{arr}mat{matrix_dim}-{idx_text}{col}{row}rd.shader_test'.format(
+ stage=stage,
+ mode=mode,
+ arr=arr,
+ matrix_dim=matrix_dim,
+ idx_text=idx_text,
+ col='col-' if col == 'col' else '',
+ row='row-' if expect == 'float' else ''),
+ TestParams(matrix_dim, array_dim, mode, 'index', col, expect,
+ glsl_version))
if __name__ == '__main__':
--
2.3.5
More information about the Piglit
mailing list