diff options
author | Martin Odersky <odersky@gmail.com> | 2003-11-25 17:35:21 +0000 |
---|---|---|
committer | Martin Odersky <odersky@gmail.com> | 2003-11-25 17:35:21 +0000 |
commit | 41d7105a224d18a98cde2c6ca1867231ddf49f45 (patch) | |
tree | 3fbcff7f3717c776e77340d5343fcb8a82be160f /sources/scalac/ast | |
parent | 9d6b31731014a192021cf9cd6f7b524ccf7bee1d (diff) | |
download | scala-41d7105a224d18a98cde2c6ca1867231ddf49f45.tar.gz scala-41d7105a224d18a98cde2c6ca1867231ddf49f45.tar.bz2 scala-41d7105a224d18a98cde2c6ca1867231ddf49f45.zip |
*** empty log message ***
Diffstat (limited to 'sources/scalac/ast')
-rw-r--r-- | sources/scalac/ast/parser/Parser.java | 28 |
1 files changed, 20 insertions, 8 deletions
diff --git a/sources/scalac/ast/parser/Parser.java b/sources/scalac/ast/parser/Parser.java index 9dacca3bc1..9fa2e92dda 100644 --- a/sources/scalac/ast/parser/Parser.java +++ b/sources/scalac/ast/parser/Parser.java @@ -209,6 +209,23 @@ public class Parser implements Tokens { return Name.fromString("x$" + (fresh++)); } + /** Create a tree representing a packaging + */ + Tree makePackaging(int pos, Tree pkg, Tree[] stats) { + while (true) { + Template templ = make.Template(pos, Tree.EMPTY_ARRAY, stats); + switch (pkg) { + case Select(Tree qual, Name name): + stats = new Tree[]{ + make.PackageDef(pos, make.Ident(pkg.pos, name), templ)}; + pkg = qual; + break; + default: + return make.PackageDef(pos, pkg, templ); + } + } + } + /** Create tree representing binary operation expression or pattern. */ Tree makeBinop(boolean isExpr, int pos, Tree left, Name op, Tree right) { @@ -1938,8 +1955,7 @@ public class Parser implements Tokens { accept(LBRACE); Tree[] stats = topStatSeq(); accept(RBRACE); - return - make.PackageDef(pos, pkg, make.Template(pos, Tree.EMPTY_ARRAY, stats)); + return makePackaging(pos, pkg, stats); } /** TopStatSeq ::= [TopStat {`;' TopStat}] @@ -2057,15 +2073,11 @@ public class Parser implements Tokens { Tree pkg = qualId(); if (s.token == SEMI) { s.nextToken(); - return new Tree[]{ - make.PackageDef( - pos, pkg, make.Template(pos, Tree.EMPTY_ARRAY, topStatSeq()))}; + return new Tree[]{makePackaging(pos, pkg, topStatSeq())}; } else { TreeList stats = new TreeList(); accept(LBRACE); - stats.append( - make.PackageDef( - pos, pkg, make.Template(pos, Tree.EMPTY_ARRAY, topStatSeq()))); + stats.append(makePackaging(pos, pkg, topStatSeq())); accept(RBRACE); stats.append(topStatSeq()); return stats.toArray(); |