From c84e4be5ce1cccc55affc1898bae3fddcba216a6 Mon Sep 17 00:00:00 2001 From: mihaylov Date: Thu, 30 Oct 2003 17:01:25 +0000 Subject: 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. --- sources/scalac/transformer/AddConstructors.java | 24 ++++++++++-------------- 1 file changed, 10 insertions(+), 14 deletions(-) (limited to 'sources') 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/**/ 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()])): -- cgit v1.2.3