#!/usr/bin/env python # Copyright (c) 2019 The Khronos Group Inc. # Use of this source code is governed by an MIT-style license that can be # found in the LICENSE.txt file. """ Generator for shadermatrix* tests. This file needs to be run in its folder. """ import sys _DO_NOT_EDIT_WARNING = """ """ _HTML_TEMPLATE = """ WebGL Shader Matrix Test
""" _GROUPS = [ 'add_const', 'add_uniform', 'add_dynamic', 'sub_const', 'sub_uniform', 'sub_dynamic', 'mul_const_lowp', 'mul_const_mediump', 'mul_const_highp', 'mul_uniform_lowp', 'mul_uniform_mediump', 'mul_uniform_highp', 'mul_dynamic_lowp', 'mul_dynamic_mediump', 'mul_dynamic_highp', 'div_const', 'div_uniform', 'div_dynamic', 'matrixcompmult', 'outerproduct', 'transpose', 'determinant', 'inverse', 'unary_addition', 'negation', 'pre_increment', 'pre_decrement', 'post_increment', 'post_decrement', 'add_assign', 'sub_assign', 'mul_assign', 'div_assign', ] def GenerateFilename(group): """Generate test filename.""" filename = group filename += ".html" return filename def WriteTest(filename, start, end): """Write one test.""" file = open(filename, "wb") file.write(_DO_NOT_EDIT_WARNING) file.write(_HTML_TEMPLATE % { 'start': start, 'end': end }) file.close def GenerateTests(): """Generate all tests.""" filelist = [] for ii in range(len(_GROUPS)): filename = GenerateFilename(_GROUPS[ii]) filelist.append(filename) WriteTest(filename, ii, ii + 1) return filelist def GenerateTestList(filelist): file = open("00_test_list.txt", "wb") file.write('\n'.join(filelist)) file.close def main(argv): """This is the main function.""" filelist = GenerateTests() GenerateTestList(filelist) if __name__ == '__main__': sys.exit(main(sys.argv[1:]))