scalar values (that ispc used to smear across the array/struct
elements). Now, initializers in variable declarations must be
{ }-delimited lists, with one element per struct member or array
element, respectively.
There were a few problems with the previous implementation of the
functionality to initialize from scalars. First, the expression
would be evaluated once per value initialized, so if it had side-effects,
the wrong thing would happen. Next, for large multidimensional arrays,
the generated code would be a long series of move instructions, rather
than loops (and this in turn made LLVM take a long time.)
While both of these problems are fixable, it's a non-trivial
amount of re-plumbing for a questionable feature anyway.
Fixes issue #50.
25 lines
581 B
Plaintext
25 lines
581 B
Plaintext
|
|
export uniform int width() { return programCount; }
|
|
|
|
|
|
struct Foo {
|
|
float x;
|
|
float f;
|
|
int i[3];
|
|
};
|
|
|
|
export void f_fu(uniform float RET[], uniform float aFOO[], uniform float b) {
|
|
float a = aFOO[programIndex];
|
|
uniform struct Foo myFoo[3] = { { b, b, {b, b, b} },
|
|
{ b, b, {b, b, b} },
|
|
{ b, b, {b, b, b} } };
|
|
uniform struct Foo barFoo;
|
|
barFoo = myFoo[0];
|
|
RET[programIndex] = barFoo.x + myFoo[1].i[2];
|
|
}
|
|
|
|
|
|
export void result(uniform float RET[4]) {
|
|
RET[programIndex] = 10;
|
|
}
|