Set lower bound on size implied by whole-array assignment
authorIan Romanick <ian.d.romanick@intel.com>
Mon, 5 Apr 2010 21:35:47 +0000 (14:35 -0700)
committerIan Romanick <ian.d.romanick@intel.com>
Mon, 5 Apr 2010 21:35:47 +0000 (14:35 -0700)
When an unsized array is accessed with a constant extension index this
sets a lower bound on the allowable sizes.  When the unsized array
gets a size set due to a whole-array assignment, this size must be at
least as large as the implied lower bound.

This causes the following tests to pass:

    glslparsertest/glsl2/array-16.vert

ast_to_hir.cpp

index c9f93cbcc426ed719caabca253bd71ba38de69d8..9d067be02d77b7b961a284d3811a872247ff3a2e 100644 (file)
@@ -489,6 +489,13 @@ do_assignment(exec_list *instructions, struct _mesa_glsl_parse_state *state,
 
         assert(var != NULL);
 
+        if (var->max_array_access >= unsigned(rhs->type->array_size())) {
+           /* FINISHME: This should actually log the location of the RHS. */
+           _mesa_glsl_error(& lhs_loc, state, "array size must be > %u due to "
+                            "previous access",
+                            var->max_array_access);
+        }
+
         var->type = glsl_type::get_array_instance(lhs->type->element_type(),
                                                   rhs->type->array_size());
       }