glsl: Add is_basis function

Determines whether it's a basis vector, i.e., a vector with one element
equal to 1 and all other elements equal to 0.

Reviewed-by: Kenneth Graunke <kenneth@whitecape.org>
This commit is contained in:
Matt Turner
2012-06-04 16:26:32 -04:00
parent d7bef19c7f
commit 9aa3fbcc2e
2 changed files with 70 additions and 4 deletions

View File

@@ -46,6 +46,11 @@ bool ir_rvalue::is_negative_one() const
return false; return false;
} }
bool ir_rvalue::is_basis() const
{
return false;
}
/** /**
* Modify the swizzle make to move one component to another * Modify the swizzle make to move one component to another
* *
@@ -1125,6 +1130,49 @@ ir_constant::is_negative_one() const
return true; return true;
} }
bool
ir_constant::is_basis() const
{
if (!this->type->is_scalar() && !this->type->is_vector())
return false;
if (this->type->is_boolean())
return false;
unsigned ones = 0;
for (unsigned c = 0; c < this->type->vector_elements; c++) {
switch (this->type->base_type) {
case GLSL_TYPE_FLOAT:
if (this->value.f[c] == 1.0)
ones++;
else if (this->value.f[c] != 0.0)
return false;
break;
case GLSL_TYPE_INT:
if (this->value.i[c] == 1)
ones++;
else if (this->value.i[c] != 0)
return false;
break;
case GLSL_TYPE_UINT:
if (int(this->value.u[c]) == 1)
ones++;
else if (int(this->value.u[c]) != 0)
return false;
break;
default:
/* The only other base types are structures, arrays, samplers, and
* booleans. Samplers cannot be constants, and the others should
* have been filtered out above.
*/
assert(!"Should not get here.");
return false;
}
}
return ones == 1;
}
ir_loop::ir_loop() ir_loop::ir_loop()
{ {
this->ir_type = ir_type_loop; this->ir_type = ir_type_loop;

View File

@@ -201,7 +201,8 @@ public:
* for vector and scalar types that have all elements set to the value * for vector and scalar types that have all elements set to the value
* zero (or \c false for booleans). * zero (or \c false for booleans).
* *
* \sa ir_constant::has_value, ir_rvalue::is_one, ir_rvalue::is_negative_one * \sa ir_constant::has_value, ir_rvalue::is_one, ir_rvalue::is_negative_one,
* ir_constant::is_basis
*/ */
virtual bool is_zero() const; virtual bool is_zero() const;
@@ -213,7 +214,8 @@ public:
* for vector and scalar types that have all elements set to the value * for vector and scalar types that have all elements set to the value
* one (or \c true for booleans). * one (or \c true for booleans).
* *
* \sa ir_constant::has_value, ir_rvalue::is_zero, ir_rvalue::is_negative_one * \sa ir_constant::has_value, ir_rvalue::is_zero, ir_rvalue::is_negative_one,
* ir_constant::is_basis
*/ */
virtual bool is_one() const; virtual bool is_one() const;
@@ -223,12 +225,27 @@ public:
* The base implementation of this function always returns \c false. The * The base implementation of this function always returns \c false. The
* \c ir_constant class over-rides this function to return \c true \b only * \c ir_constant class over-rides this function to return \c true \b only
* for vector and scalar types that have all elements set to the value * for vector and scalar types that have all elements set to the value
* negative one. For boolean times, the result is always \c false. * negative one. For boolean types, the result is always \c false.
* *
* \sa ir_constant::has_value, ir_rvalue::is_zero, ir_rvalue::is_one * \sa ir_constant::has_value, ir_rvalue::is_zero, ir_rvalue::is_one
* ir_constant::is_basis
*/ */
virtual bool is_negative_one() const; virtual bool is_negative_one() const;
/**
* Determine if an r-value is a basis vector
*
* The base implementation of this function always returns \c false. The
* \c ir_constant class over-rides this function to return \c true \b only
* for vector and scalar types that have one element set to the value one,
* and the other elements set to the value zero. For boolean types, the
* result is always \c false.
*
* \sa ir_constant::has_value, ir_rvalue::is_zero, ir_rvalue::is_one,
* is_constant::is_negative_one
*/
virtual bool is_basis() const;
/** /**
* Return a generic value of error_type. * Return a generic value of error_type.
@@ -1743,13 +1760,14 @@ public:
* Determine whether a constant has the same value as another constant * Determine whether a constant has the same value as another constant
* *
* \sa ir_constant::is_zero, ir_constant::is_one, * \sa ir_constant::is_zero, ir_constant::is_one,
* ir_constant::is_negative_one * ir_constant::is_negative_one, ir_constant::is_basis
*/ */
bool has_value(const ir_constant *) const; bool has_value(const ir_constant *) const;
virtual bool is_zero() const; virtual bool is_zero() const;
virtual bool is_one() const; virtual bool is_one() const;
virtual bool is_negative_one() const; virtual bool is_negative_one() const;
virtual bool is_basis() const;
/** /**
* Value of the constant. * Value of the constant.