diff options
| author | 2022-08-26 09:58:48 +0200 | |
|---|---|---|
| committer | 2022-08-26 09:58:48 +0200 | |
| commit | 5ba53665c99c01f407576406b4c619d180efd384 (patch) | |
| tree | 36257820de7d3d8a9cf21eee6cea9d3e38f93eda /src/parse.cff | |
| parent | d42f8309b4af19966ad9c7b575918ee14421cee1 (diff) | |
some fixes + .[] syntax sugar
Diffstat (limited to 'src/parse.cff')
| -rw-r--r-- | src/parse.cff | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/src/parse.cff b/src/parse.cff index f03e13a..d4b8b7a 100644 --- a/src/parse.cff +++ b/src/parse.cff @@ -1658,6 +1658,13 @@ fn pexpostfix(P *Parser) Expr { let enumty = ty.u.Agg.enumty; ex = { tok.loc, ty.konst ? constify(enumty) : enumty, :EUTag(exprdup(P.alloc, ex)) }; + case lexpeek(P).t == '['; + // sugar: expr.[idx] -> (*expr)[idx] + if !ex.ty->is(:Ptr) { + fatal(P, ex.loc, "`.[]' operator takes a pointer (got %t)", ex.ty); + } + ex = { ex.loc, ex.ty.u.Ptr, .u: :UnOp { :deref, exprdup(P.alloc, ex) }}; + case else; lexexpects(P, :ident, "field name"); } |