summaryrefslogtreecommitdiffstats
path: root/dom/canvas/test/webgl-conf/checkout/conformance2/glsl3/array-in-complex-expression.html
blob: 9e55a0a01604010e4db75d62d27a584ba1656303 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
<!--
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.
-->

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>GLSL array in complex expression test</title>
<link rel="stylesheet" href="../../resources/js-test-style.css"/>
<script src="../../js/js-test-pre.js"></script>
<script src="../../js/webgl-test-utils.js"></script>
<script src="../../js/glsl-conformance-test.js"></script>
</head>
<body>
<div id="description"></div>
<div id="console"></div>
<script id="fshaderAndShortCircuits" type="x-shader/x-fragment">#version 300 es
precision mediump float;

out vec4 my_FragColor;

int g = 0;

int[2] plus() {
    ++g;
    return int[2](g, g);
}

bool minus() {
    --g;
    return false;
}

void main() {
    int a[2] = int[2](0, 0);
    // The function call must not be evaluated, since && short-circuits
    minus() && (a == plus());
    my_FragColor = vec4(0.0, ((g == -1) ? 1.0 : 0.0), 0.0, 1.0);
}
</script>
<script id="fshaderOrShortCircuits" type="x-shader/x-fragment">#version 300 es
precision mediump float;

out vec4 my_FragColor;

int g = 0;

int[2] plus() {
    ++g;
    return int[2](g, g);
}

bool minus() {
    --g;
    return true;
}

void main() {
    int a[2] = int[2](0, 0);
    // The function call must not be evaluated, since || short-circuits.
    minus() || (a == plus());
    my_FragColor = vec4(0.0, ((g == -1) ? 1.0 : 0.0), 0.0, 1.0);
}
</script>
<script id="fshaderTernaryOnlyEvaluatesOneOperand" type="x-shader/x-fragment">#version 300 es
precision mediump float;

out vec4 my_FragColor;

int g = 0;

int[2] plus() {
    ++g;
    return int[2](g, g);
}

void main() {
    int a[2] = int[2](0, 0);
    // The function call must not be evaluated, since the condition is true.
    (g == 0) ? true : (a == plus());
    my_FragColor = vec4(0.0, ((g == 0) ? 1.0 : 0.0), 0.0, 1.0);
}
</script>
<script id="fshaderSequenceSideEffectsAffectingComparedArrayContent" type="x-shader/x-fragment">#version 300 es
precision mediump float;

out vec4 my_FragColor;

int[2] func(int param) {
    return int[2](param, param);
}

void main() {
    int a[2];
    for (int i = 0; i < 2; ++i) {
        a[i] = 1;
    }
    int j = 0;
    // Sequence operator evaluates operands from left to right (ESSL 3.00 section 5.9).
    // The function call that returns the array needs to be evaluated after ++j
    // for the expression to return the correct value (true).
    bool result = ((++j), (a == func(j)));
    my_FragColor = vec4(0.0, (result ? 1.0 : 0.0), 0.0, 1.0);
}
</script>
<script type="application/javascript">
"use strict";
description("Arrays in complex expressions should work");
debug("");
debug("This test is targeted to stress syntax tree transformations that might need to be done in shader translation when the platform doesn't natively support arrays as return values.");

GLSLConformanceTester.runRenderTests([
{
  fShaderId: 'fshaderAndShortCircuits',
  fShaderSuccess: true,
  linkSuccess: true,
  passMsg: "Expression where an array is returned from a function call inside an operand to && that doesn't get evaluated as result of short-circuiting"
},
{
  fShaderId: 'fshaderOrShortCircuits',
  fShaderSuccess: true,
  linkSuccess: true,
  passMsg: "Expression where an array is returned from a function call inside an operand to || that doesn't get evaluated as result of short-circuiting"
},
{
  fShaderId: 'fshaderTernaryOnlyEvaluatesOneOperand',
  fShaderSuccess: true,
  linkSuccess: true,
  passMsg: "Expression where an array is returned from a function call in an operand of a ternary operator that doesn't get evaluated"
},
{
  fShaderId: 'fshaderSequenceSideEffectsAffectingComparedArrayContent',
  fShaderSuccess: true,
  linkSuccess: true,
  passMsg: 'Expression where first operand of a sequence operator has side effects which affect the second operand that returns an array'
}
], 2);
</script>
</body>
</html>