On 25 October 2011 16:55, Kenneth Graunke <[email protected]> wrote:
> On 10/25/2011 04:47 PM, Paul Berry wrote:
> > This function is similar to get_base_type(), but when called on
> > arrays, it returns the scalar type composing the array. For example,
> > glsl_type(vec4[]) => float_type.
> > ---
> > src/glsl/glsl_types.cpp | 23 +++++++++++++++++++++++
> > src/glsl/glsl_types.h | 11 +++++++++++
> > 2 files changed, 34 insertions(+), 0 deletions(-)
> >
> > diff --git a/src/glsl/glsl_types.cpp b/src/glsl/glsl_types.cpp
> > index c94aec0..03e9987 100644
> > --- a/src/glsl/glsl_types.cpp
> > +++ b/src/glsl/glsl_types.cpp
> > @@ -258,6 +258,29 @@ const glsl_type *glsl_type::get_base_type() const
> > }
> >
> >
> > +const glsl_type *glsl_type::get_scalar_type() const
> > +{
> > + const glsl_type *type = this;
> > +
> > + /* Handle arrays */
> > + while (type->base_type == GLSL_TYPE_ARRAY)
> > + type = type->fields.array;
>
> This is going to be a very short loop; in fact, it's actually equivalent
> to:
>
> if (type->base_type == GLSL_TYPE_ARRAY)
> type = type->fields.array;
>
> since GLSL explicitly disallows arrays of arrays. That said, it doesn't
> really hurt anything, so I'm more observing this than objecting to the
> code.
>
>
That's a fair point. I think I prefer to leave it as originally written, on
the theory that if arrays of arrays are ever allowed, then the loop will be
required. But it's not a strong preference.
_______________________________________________
mesa-dev mailing list
[email protected]
http://lists.freedesktop.org/mailman/listinfo/mesa-dev