#!/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:]))