do
var mtype = self.mtype.as(MClassType).arguments.first
var array = new Array[RuntimeVariable]
- for nexpr in self.n_exprs.n_exprs do
+ for nexpr in self.n_exprs do
var i = v.expr(nexpr, mtype)
array.add(i)
end
redef fun expr(v)
do
var val = new Array[Instance]
- for nexpr in self.n_exprs.n_exprs do
+ for nexpr in self.n_exprs do
var i = v.expr(nexpr)
if i == null then return null
val.add(i)
// !nopar to unambiguise 'foo[5].bar' between '(foo[5]).bar' and 'foo([5].bar),
!nobra!nopar | {range} obra no expr [n2]:no dotdot [n3]:no [expr2]:expr_nobra [n4]:no cbra annotations_o {-> New expr.crange(obra, expr, expr2.expr, cbra, annotations_o.annotations)}
!nobra!nopar | {orange} obra no expr [n2]:no dotdot [n3]:no [expr2]:expr_nobra [n4]:no [cbra]:obra annotations_o {-> New expr.orange(obra, expr, expr2.expr, cbra, annotations_o.annotations)}
-!nobra!nopar | {array} obra no args_list typing_o cbra annotations_o {-> New expr.array(obra, args_list.exprs, typing_o.type, cbra, annotations_o.annotations)}
+!nobra!nopar | {array} obra no array_items typing_o cbra annotations_o {-> New expr.array(obra, [array_items.expr], typing_o.type, cbra, annotations_o.annotations)}
;
expr_par {-> expr}
= comma no any_expr {-> any_expr.expr}
;
+array_items {-> expr*}
+ = array_item array_items_tail* {-> [array_item.expr, array_items_tail.expr]}
+ ;
+array_items_tail {-> expr}
+ = comma no array_item {-> array_item.expr}
+ ;
+array_item {-> expr}
+ = expr no {-> expr}
+ ;
+
superstring {-> expr}
= superstring_start superstring_middle* superstring_end annotations_o {-> New expr.superstring([superstring_start.expr, superstring_middle.expr, superstring_end.expr], annotations_o.annotations)};
superstring_start {-> expr*}
| {range} expr [expr2]:expr annotations?
| {crange} obra expr [expr2]:expr cbra annotations?
| {orange} obra expr [expr2]:expr [cbra]:obra annotations?
- | {array} obra [exprs]:exprs type? cbra annotations?
+ | {array} obra [exprs]:expr* type? cbra annotations?
| {self} kwself annotations?
| {implicit_self}
| {true} kwtrue annotations?
class AArrayExpr
super AExpr
var n_obra: TObra is writable, noinit
- var n_exprs: AExprs is writable, noinit
+ var n_exprs: List[AExpr] = new List[AExpr]
var n_type: nullable AType = null is writable
var n_cbra: TCbra is writable, noinit
var n_annotations: nullable AAnnotations = null is writable
class AArrayExpr
super AExpr
var n_obra: TObra is writable, noinit
- var n_exprs: AExprs is writable, noinit
+ var n_exprs = new ANodes[AExpr](self)
var n_type: nullable AType = null is writable
var n_cbra: TCbra is writable, noinit
end
redef class AArrayExpr
redef fun accept_pretty_printer(v) do
v.consume "["
- v.visit_list n_exprs.n_exprs
+ v.visit_list n_exprs
v.consume "]"
end
end
end
var mtypes = new Array[nullable MType]
var useless = false
- for e in self.n_exprs.n_exprs do
+ for e in self.n_exprs do
var t = v.visit_expr(e)
if t == null then
return # Skip error
do
var nblock = v.builder.make_block
- var nnew = v.builder.make_new(with_capacity_callsite.as(not null), [v.builder.make_int(n_exprs.n_exprs.length)])
+ var nnew = v.builder.make_new(with_capacity_callsite.as(not null), [v.builder.make_int(n_exprs.length)])
nblock.add nnew
- for nexpr in self.n_exprs.n_exprs do
+ for nexpr in self.n_exprs do
var nadd = v.builder.make_call(nnew.make_var_read, push_callsite.as(not null), [nexpr])
nblock.add nadd
end