diff options
author | Timothy Arceri <t_arceri@yahoo.com.au> | 2014-01-23 23:21:02 +1100 |
---|---|---|
committer | Timothy Arceri <t_arceri@yahoo.com.au> | 2014-01-23 23:37:36 +1100 |
commit | 61a584609936940f69207dd520b5b4208810a9e7 (patch) | |
tree | 788814508be195f11b2e1c08cd1cadd4b24e2b86 /src/glsl | |
parent | 3d492f19f6e1a50a645cfa3b04d64808d44af5e3 (diff) | |
download | external_mesa3d-61a584609936940f69207dd520b5b4208810a9e7.zip external_mesa3d-61a584609936940f69207dd520b5b4208810a9e7.tar.gz external_mesa3d-61a584609936940f69207dd520b5b4208810a9e7.tar.bz2 |
glsl: create type name for arrays of arrays
We need to insert outermost dimensions in the correct spot otherwise
the dimension order will be backwards
Signed-off-by: Timothy Arceri <t_arceri@yahoo.com.au>
Reviewed-by: Paul Berry <stereotype441@gmail.com>
Diffstat (limited to 'src/glsl')
-rw-r--r-- | src/glsl/glsl_types.cpp | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/src/glsl/glsl_types.cpp b/src/glsl/glsl_types.cpp index f9bb0cf..1b0b3ef 100644 --- a/src/glsl/glsl_types.cpp +++ b/src/glsl/glsl_types.cpp @@ -300,8 +300,20 @@ glsl_type::glsl_type(const glsl_type *array, unsigned length) : if (length == 0) snprintf(n, name_length, "%s[]", array->name); - else - snprintf(n, name_length, "%s[%u]", array->name, length); + else { + /* insert outermost dimensions in the correct spot + * otherwise the dimension order will be backwards + */ + const char *pos = strchr(array->name, '['); + if (pos) { + int idx = pos - array->name; + snprintf(n, idx+1, "%s", array->name); + snprintf(n + idx, name_length - idx, "[%u]%s", + length, array->name + idx); + } else { + snprintf(n, name_length, "%s[%u]", array->name, length); + } + } this->name = n; } |