diff options
author | buraq <buraq@epfl.ch> | 2004-06-07 16:11:46 +0000 |
---|---|---|
committer | buraq <buraq@epfl.ch> | 2004-06-07 16:11:46 +0000 |
commit | 706cd4cf87157ccb6863811edae5a374bf2a3a03 (patch) | |
tree | 1a0cd874899b5d8a99ef153083f622fc6df045f1 /sources/scalac | |
parent | 61b0435b649aa845fb06533464edc239990b4927 (diff) | |
download | scala-706cd4cf87157ccb6863811edae5a374bf2a3a03.tar.gz scala-706cd4cf87157ccb6863811edae5a374bf2a3a03.tar.bz2 scala-706cd4cf87157ccb6863811edae5a374bf2a3a03.zip |
ant task fixed up,
symbol classes public
testregtraverser obsolete
Diffstat (limited to 'sources/scalac')
-rw-r--r-- | sources/scalac/transformer/matching/TestRegTraverser.java | 106 |
1 files changed, 0 insertions, 106 deletions
diff --git a/sources/scalac/transformer/matching/TestRegTraverser.java b/sources/scalac/transformer/matching/TestRegTraverser.java deleted file mode 100644 index e5dae1fc6a..0000000000 --- a/sources/scalac/transformer/matching/TestRegTraverser.java +++ /dev/null @@ -1,106 +0,0 @@ -/* ____ ____ ____ ____ ______ *\ -** / __// __ \/ __// __ \/ ____/ SOcos COmpiles Scala ** -** __\_ \/ /_/ / /__/ /_/ /\_ \ (c) 2002, LAMP/EPFL ** -** /_____/\____/\___/\____/____/ ** -** ** -** $Id$ -\* */ - -package scalac.transformer.matching; - -import scalac.Global; -import scalac.ast.*; -import scalac.util.*; -import scalac.symtab.*; -import java.util.*; - - -public class TestRegTraverser extends Traverser { - boolean result = false; - Set variables = new HashSet(); - static Set nilVariables = new HashSet(); - - public void traverse(Tree tree) { - //System.out.println("traverse:"+tree); - if (!result) - switch (tree) { - case Alternative(_): - result = true; - break; - case Bind(Name n, Tree pat): - if( TreeInfo.isNameOfStarPattern( n ) ) { - result = true; - } - if( TreeInfo.isEmptySequence( pat ) ) { - // annoying special case: b@() [or b@(()|()) after normalization] - //System.err.println("bindin empty "+tree.symbol()); - nilVariables.add(tree.symbol()); - result = true; - } else { - variables.add(tree.symbol()); - } - traverse(pat); - break; - case Ident(_): - Symbol symbol = tree.symbol(); - if ((symbol != Global.instance.definitions.PATTERN_WILDCARD) && - variables.contains(symbol)) - result = true; - break; - case CaseDef(Tree pat, _, _): - traverse(pat); - break; - - case Sequence( Tree[] trees): - if( trees.length == 0 ) { - result = true; - break; - } else traverse( trees ); - //result = true; - break; - - case Apply(Tree fun, Tree[] args): - traverse(fun); - traverse(args); - if(( args.length == 1 )&&TreeInfo.isEmptySequence(args[ 0 ])) - result = false; - return; - // Matthias PatternMatcher cannot handle this case - /* - case Apply( Tree fn, Tree[] trees ): - if( trees.length == 1 ) - switch (trees[ 0 ]) { - - case Sequence( Tree[] trees2 ): - if( trees2.length == 1 ) { - switch (trees2[ 0 ]) { - case Sequence( Tree[] trees3 ): - result = true; - break; - } - //System.out.println( fn ); - //System.out.println( tree.type() ); - } else super.traverse( tree ); - break; - default: - super.traverse( tree ); - } - break; - */ - default: - super.traverse( tree ); - } - } - - public static boolean apply(Tree t) { - TestRegTraverser trt = new TestRegTraverser(); - nilVariables.clear(); - trt.traverse(t); - //System.out.println("TestRegTraverser says "+t+" -> "+trt.result); - return trt.result; - } - - public static Set getNilVariables() { - return nilVariables; - } -} |