# -*- coding: utf-8 -*-
#-------------------------------------------------------------------------
# drawElements Quality Program utilities
# --------------------------------------
#
# Copyright (c) 2016 The Khronos Group Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
#-------------------------------------------------------------------------
import sys
import string
from genutil import *
# Templates
INVALID_IMPLICIT_CONVESION_TEMPLATE0 = """
case ${{NAME}}
expect compile_fail
version 300 es
both ""
#version 300 es
precision mediump float;
precision mediump int;
${DECLARATIONS}
void main()
{
${{TYPE0}} c;
${{TYPE0}} a;
${{TYPE1}} b;
${{TYPE0}} c = a ${{OPERATION}} b;
}
""
end
"""[1:-1]
INVALID_IMPLICIT_CONVESION_TEMPLATE1 = """
case ${{NAME}}
expect compile_fail
version 300 es
both ""
#version 300 es
precision mediump float;
precision mediump int;
${DECLARATIONS}
void main()
{
${{TYPE1}} c;
${{TYPE0}} a;
${{TYPE1}} b;
${{TYPE1}} c = a ${{OPERATION}} b;
}
""
end
"""[1:-1]
arithOperations = {'+': 'add', '*':'mul', '/': 'div', '-':'sub'}
class InvalidImplicitConversionCase(ShaderCase):
def __init__(self, operation, type0, type1):
self.name = arithOperations[operation] + '_' + type0 + '_' + type1
self.operation = operation
self.type0 = type0
self.type1 = type1
def __str__(self):
params0 = { "NAME": self.name + '_' + self.type0, "TYPE0": self.type0, "TYPE1": self.type1, "OPERATION": self.operation }
params1 = { "NAME": self.name + '_' + self.type1, "TYPE0": self.type0, "TYPE1": self.type1, "OPERATION": self.operation }
return fillTemplate(INVALID_IMPLICIT_CONVESION_TEMPLATE0, params0) + '\n' + fillTemplate(INVALID_IMPLICIT_CONVESION_TEMPLATE1, params1)
def createCase(operation, type0, type1):
cases = []
for t0 in type0:
for t1 in type1:
case = InvalidImplicitConversionCase(operation, t0, t1)
cases.append(case)
return cases
floats = ['float', 'vec2', 'vec3', 'vec4']
sintegers = ['int', 'ivec2', 'ivec3', 'ivec4']
uintegers = ['uint', 'uvec2', 'uvec3', 'uvec4']
cases = []
for op in arithOperations:
caseFpInt = createCase(op, floats, sintegers)
cases = cases + caseFpInt
caseFpUint = createCase(op, floats, uintegers)
cases = cases + caseFpUint
caseIntUint = createCase(op, sintegers, uintegers)
cases = cases + caseIntUint
invalidImplicitConversionCases = [
CaseGroup("invalid_implicit_conversions", "Invalid Implicit Conversions", cases),
]
if __name__ == "__main__":
print "Generating shader case files."
writeAllCases("invalid_implicit_conversions.test", invalidImplicitConversionCases)