summaryrefslogtreecommitdiff
path: root/sources
diff options
context:
space:
mode:
authorpaltherr <paltherr@epfl.ch>2003-10-31 18:14:50 +0000
committerpaltherr <paltherr@epfl.ch>2003-10-31 18:14:50 +0000
commit1115a0305cb27bb3697a561f056896ff1d9f53d6 (patch)
tree6aededc6015ac120d98c5aa8392a1ab2aa0ce787 /sources
parent81288e4e3e762adfd8ecc9f738eb63e43bd4f09b (diff)
downloadscala-1115a0305cb27bb3697a561f056896ff1d9f53d6.tar.gz
scala-1115a0305cb27bb3697a561f056896ff1d9f53d6.tar.bz2
scala-1115a0305cb27bb3697a561f056896ff1d9f53d6.zip
- Fixed problem with <init> methods
Diffstat (limited to 'sources')
-rw-r--r--sources/scala/tools/scalai/Environment.java14
-rw-r--r--sources/scala/tools/scalai/ExpressionCompiler.java1
2 files changed, 9 insertions, 6 deletions
diff --git a/sources/scala/tools/scalai/Environment.java b/sources/scala/tools/scalai/Environment.java
index 3465392320..c307929f1a 100644
--- a/sources/scala/tools/scalai/Environment.java
+++ b/sources/scala/tools/scalai/Environment.java
@@ -198,12 +198,14 @@ public class Environment {
private void loadMethodOverride(Type[] bases, Symbol symbol) {
if (!symbol.isMethod()) return;
Override override = Override.empty().insert(symbol);
- if (symbol.isExternal()) override.insert(mirror.getMethod(symbol));
- for (int i = 0; i < bases.length; i++) {
- Symbol overridden = symbol.overriddenSymbol(bases[i], true);
- if (overridden == Symbol.NONE) continue;
- assert Debug.log("update override: ", symbol, " <- ", overridden);
- override.insert(lookupOverride(overridden));
+ if (!symbol.isInitializer()) {
+ if (symbol.isExternal()) override.insert(mirror.getMethod(symbol));
+ for (int i = 0; i < bases.length; i++) {
+ Symbol overridden = symbol.overriddenSymbol(bases[i], true);
+ if (overridden == Symbol.NONE) continue;
+ assert Debug.log("update override: ",symbol," <- ",overridden);
+ override.insert(lookupOverride(overridden));
+ }
}
insertOverride(symbol, override);
}
diff --git a/sources/scala/tools/scalai/ExpressionCompiler.java b/sources/scala/tools/scalai/ExpressionCompiler.java
index 9cdbb483bc..0dee99ba8a 100644
--- a/sources/scala/tools/scalai/ExpressionCompiler.java
+++ b/sources/scala/tools/scalai/ExpressionCompiler.java
@@ -257,6 +257,7 @@ public class ExpressionCompiler {
break;
case JavaClass(Class clasz):
+ if (symbol.isInitializer()) break;
throw Debug.abort("!!! illegal super on java class", symbol);
default: