blob: a3f81289c9b0a2f44cb8fca0704c628288f78f04 (
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
|
/*
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.
*/
#ifdef GL_ES
precision mediump float;
#endif
varying vec4 color;
void qualifiers(in float a[4], out float b[4], inout float c[4], const in float d[4], float e[4])
{
b[0] = a[0];
c[0] += d[0];
a[0] += 1.0;
e[0] += 1.0;
b[1] = a[1];
c[1] += d[1];
a[1] += 1.0;
e[1] += 1.0;
b[2] = a[2];
c[2] += d[2];
a[2] += 1.0;
e[2] += 1.0;
b[3] = a[3];
c[3] += d[3];
a[3] += 1.0;
e[3] += 1.0;
}
void main (void)
{
float a[4];
float b[4];
float c[4];
float d[4];
float e[4];
float q = 0.0;
float q2 = 0.0;
a[0] = 1.0;
b[0] = 2.0;
c[0] = 3.0;
d[0] = 4.0;
e[0] = 1.0;
a[1] = 1.0;
b[1] = 2.0;
c[1] = 3.0;
d[1] = 4.0;
e[1] = 1.0;
a[2] = 1.0;
b[2] = 2.0;
c[2] = 3.0;
d[2] = 4.0;
e[2] = 1.0;
a[3] = 1.0;
b[3] = 2.0;
c[3] = 3.0;
d[3] = 4.0;
e[3] = 1.0;
qualifiers(a, b, c, d, e);
// randomly test a value
if(a[0] == 1.0) q += 1.0;
if(b[1] == 1.0) q += 2.0;
if(c[2] == 7.0) q += 4.0;
if(d[3] == 4.0) q2 += 1.0;
if(e[0] == 1.0) q2 += 2.0;
gl_FragColor = vec4(vec2(q / 7.0, q2 / 3.0), 1.0, 1.0);
}
|