diff options
author | mihaylov <mihaylov@epfl.ch> | 2003-10-30 17:01:25 +0000 |
---|---|---|
committer | mihaylov <mihaylov@epfl.ch> | 2003-10-30 17:01:25 +0000 |
commit | c84e4be5ce1cccc55affc1898bae3fddcba216a6 (patch) | |
tree | e3d08dab6e24fa77edd2c74173446533e1f5038d /sources/scalac | |
parent | 50db43a6e492b2ed1c8d0cbc796cb7a432a5d43e (diff) | |
download | scala-c84e4be5ce1cccc55affc1898bae3fddcba216a6.tar.gz scala-c84e4be5ce1cccc55affc1898bae3fddcba216a6.tar.bz2 scala-c84e4be5ce1cccc55affc1898bae3fddcba216a6.zip |
Removed the special cases for the JVM backend; ...
Removed the special cases for the JVM backend; MSIL backend will now
expect the same input as the JVM backend.
Diffstat (limited to 'sources/scalac')
-rw-r--r-- | sources/scalac/transformer/AddConstructors.java | 24 |
1 files changed, 10 insertions, 14 deletions
diff --git a/sources/scalac/transformer/AddConstructors.java b/sources/scalac/transformer/AddConstructors.java index bb71b167df..43c19e27fb 100644 --- a/sources/scalac/transformer/AddConstructors.java +++ b/sources/scalac/transformer/AddConstructors.java @@ -54,9 +54,6 @@ public class AddConstructors extends Transformer { // True iff we generate code for INT backend. protected final boolean forINT; - // True iff we generate code for JVM backend. - protected final boolean forJVM; - protected final HashMap/*<Symbol, Symbol>*/ constructors; @@ -64,7 +61,6 @@ public class AddConstructors extends Transformer { super(global); this.constructors = constructors; this.forINT = global.target == global.TARGET_INT; - this.forJVM = (global.target == global.TARGET_JVM); } /** return new constructor symbol if it isn't already defined @@ -84,8 +80,8 @@ public class AddConstructors extends Transformer { new TermSymbol(classConstr.pos, classConstr.name, owner, flags); Type constrType = Type.MethodType - (paramSyms, forJVM ? - global.definitions.UNIT_TYPE() : owner.type()); + (paramSyms, forINT ? owner.type() + : global.definitions.UNIT_TYPE()); if (tparamSyms.length != 0) constrType = Type.PolyType(tparamSyms, constrType); @@ -151,9 +147,9 @@ public class AddConstructors extends Transformer { if (sym.isConstructor()) { // add result expression consistent with the // result type of the constructor - Tree result = forJVM - ? gen.mkUnitLit(t.pos) - : gen.This(t.pos, treeSym); + Tree result = forINT + ? gen.This(t.pos, treeSym) + : gen.mkUnitLit(t.pos); rhs = gen.mkBlock(new Tree[] { rhs, result }); t = gen.DefDef(getConstructor(sym), rhs); } @@ -175,7 +171,9 @@ public class AddConstructors extends Transformer { Tree superConstr = gen.Select (gen.Super(pos, treeSym), getConstructor(fun.symbol())); - constrBody.add(gen.mkApplyTV(superConstr, transform(targs), transform(args))); + constrBody.add(gen.mkApplyTV(superConstr, + transform(targs), + transform(args))); break; case Apply(Tree fun, Tree[] args): int pos = impl.parents[0].pos; @@ -218,10 +216,8 @@ public class AddConstructors extends Transformer { // add result expression consistent with the // result type of the constructor - if (! forJVM) - constrBody.add(gen.This(tree.pos, treeSym)); - else - constrBody.add(gen.mkUnitLit(tree.pos)); + constrBody.add(forINT ? gen.This(tree.pos, treeSym) + : gen.mkUnitLit(tree.pos)); Tree constrTree = constrBody.size() > 1 ? gen.Block((Tree[])constrBody. toArray(new Tree[constrBody.size()])): |