Type convert arrays in select expressions to pointers to the first element.
Fixes issue #345.
This commit is contained in:
20
expr.cpp
20
expr.cpp
@@ -3274,15 +3274,19 @@ SelectExpr::TypeCheck() {
|
|||||||
if (!type1 || !type2)
|
if (!type1 || !type2)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (CastType<ArrayType>(type1)) {
|
if (const ArrayType *at1 = CastType<ArrayType>(type1)) {
|
||||||
Error(pos, "Array type \"%s\" can't be used in select expression",
|
expr1 = TypeConvertExpr(expr1, PointerType::GetUniform(at1->GetBaseType()),
|
||||||
type1->GetString().c_str());
|
"select");
|
||||||
return NULL;
|
if (expr1 == NULL)
|
||||||
|
return NULL;
|
||||||
|
type1 = expr1->GetType();
|
||||||
}
|
}
|
||||||
if (CastType<ArrayType>(type2)) {
|
if (const ArrayType *at2 = CastType<ArrayType>(type2)) {
|
||||||
Error(pos, "Array type \"%s\" can't be used in select expression",
|
expr2 = TypeConvertExpr(expr2, PointerType::GetUniform(at2->GetBaseType()),
|
||||||
type2->GetString().c_str());
|
"select");
|
||||||
return NULL;
|
if (expr2 == NULL)
|
||||||
|
return NULL;
|
||||||
|
type2 = expr2->GetType();
|
||||||
}
|
}
|
||||||
|
|
||||||
const Type *testType = test->GetType();
|
const Type *testType = test->GetType();
|
||||||
|
|||||||
18
tests/select-array-ptr-typeconv.ispc
Normal file
18
tests/select-array-ptr-typeconv.ispc
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
|
||||||
|
uniform float a[1234];
|
||||||
|
|
||||||
|
float * uniform func(uniform bool x) {
|
||||||
|
return x ? a : NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
export uniform int width() { return programCount; }
|
||||||
|
|
||||||
|
export void f_f(uniform float RET[], uniform float aFOO[]) {
|
||||||
|
a[programIndex] = aFOO[programIndex];
|
||||||
|
float * uniform ptr = func(aFOO[0] == 1);
|
||||||
|
RET[programIndex] = ptr[programIndex];
|
||||||
|
}
|
||||||
|
|
||||||
|
export void result(uniform float RET[]) {
|
||||||
|
RET[programIndex] = 1 + programIndex;
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user