X-Git-Url: http://nitlanguage.org diff --git a/src/semantize/scope.nit b/src/semantize/scope.nit index 4106660..e595b1c 100644 --- a/src/semantize/scope.nit +++ b/src/semantize/scope.nit @@ -377,9 +377,6 @@ redef class ALoopExpr end redef class AForExpr - # The automatic variables in order - var variables: nullable Array[Variable] - # The break escape mark associated with the 'for' var break_mark: nullable EscapeMark @@ -388,18 +385,22 @@ redef class AForExpr redef fun accept_scope_visitor(v) do - v.enter_visit(n_expr) + for g in n_groups do + v.enter_visit(g.n_expr) + end # Protect automatic variables v.scopes.unshift(new Scope) - # Create the automatic variables - var variables = new Array[Variable] - self.variables = variables - for nid in n_ids do - var va = new Variable(nid.text) - v.register_variable(nid, va) - variables.add(va) + for g in n_groups do + # Create the automatic variables + var variables = new Array[Variable] + g.variables = variables + for nid in g.n_ids do + var va = new Variable(nid.text) + v.register_variable(nid, va) + variables.add(va) + end end var escapemark = v.make_escape_mark(n_label, true) @@ -411,6 +412,11 @@ redef class AForExpr end end +redef class AForGroup + # The automatic variables in order + var variables: nullable Array[Variable] +end + redef class AWithExpr # The break escape mark associated with the 'with' var break_mark: nullable EscapeMark @@ -446,7 +452,7 @@ redef class ACallFormExpr redef fun accept_scope_visitor(v) do if n_expr isa AImplicitSelfExpr then - var name = n_id.text + var name = n_qid.n_id.text var variable = v.search_variable(name) if variable != null then var n: AExpr @@ -473,14 +479,14 @@ redef class ACallExpr redef fun variable_create(variable) do variable.warn_unread = false - return new AVarExpr.init_avarexpr(n_id) + return new AVarExpr.init_avarexpr(n_qid.n_id) end end redef class ACallAssignExpr redef fun variable_create(variable) do - return new AVarAssignExpr.init_avarassignexpr(n_id, n_assign, n_value) + return new AVarAssignExpr.init_avarassignexpr(n_qid.n_id, n_assign, n_value) end end @@ -488,6 +494,6 @@ redef class ACallReassignExpr redef fun variable_create(variable) do variable.warn_unread = false - return new AVarReassignExpr.init_avarreassignexpr(n_id, n_assign_op, n_value) + return new AVarReassignExpr.init_avarreassignexpr(n_qid.n_id, n_assign_op, n_value) end end