summaryrefslogtreecommitdiff
path: root/sources/scalac/symtab
diff options
context:
space:
mode:
authorMartin Odersky <odersky@gmail.com>2003-11-21 10:14:16 +0000
committerMartin Odersky <odersky@gmail.com>2003-11-21 10:14:16 +0000
commitd9fad519e8d13b10e38649f5605c3d7009bca558 (patch)
tree33dc32435ea7d0b0c590a1be4b5424d1c57c4ded /sources/scalac/symtab
parentc69637585f3d084b73d492371b45f4ab178fd438 (diff)
downloadscala-d9fad519e8d13b10e38649f5605c3d7009bca558.tar.gz
scala-d9fad519e8d13b10e38649f5605c3d7009bca558.tar.bz2
scala-d9fad519e8d13b10e38649f5605c3d7009bca558.zip
*** empty log message ***
Diffstat (limited to 'sources/scalac/symtab')
-rw-r--r--sources/scalac/symtab/Symbol.java6
-rw-r--r--sources/scalac/symtab/Type.java20
2 files changed, 23 insertions, 3 deletions
diff --git a/sources/scalac/symtab/Symbol.java b/sources/scalac/symtab/Symbol.java
index 3c2ec7d70c..967cd6a6ab 100644
--- a/sources/scalac/symtab/Symbol.java
+++ b/sources/scalac/symtab/Symbol.java
@@ -1157,7 +1157,7 @@ public abstract class Symbol implements Modifiers, Kinds {
assert this.name == that.name : Debug.show(this) + " <> " + Debug.show(that);
assert this.owner == that.owner : Debug.show(this) + " != " + Debug.show(that);
assert this.isConstructor() == that.isConstructor();
- int overflags = (this.flags & that.flags & (JAVA | ACCESSFLAGS)) |
+ int overflags = (this.flags & that.flags & (JAVA | ACCESSFLAGS | DEFERRED)) |
((this.flags | that.flags) & ACCESSOR);
TermSymbol overloaded = (this.isConstructor())
? TermSymbol.newConstructor(this.constructorClass(), overflags)
@@ -1880,8 +1880,8 @@ public class ClassSymbol extends TypeSymbol {
} else {
sym = it.next();
while ((sym.flags & SYNTHETIC) == 0) {
- System.out.println("skipping " + sym);
- sym = it.next();
+ //System.out.println("skipping " + sym);
+ sym = it.next();
}
for (int i = 0; i < index; i++)
sym = it.next();
diff --git a/sources/scalac/symtab/Type.java b/sources/scalac/symtab/Type.java
index e9a220fd55..1122d61f55 100644
--- a/sources/scalac/symtab/Type.java
+++ b/sources/scalac/symtab/Type.java
@@ -880,6 +880,7 @@ public class Type implements Modifiers, Kinds, TypeTags, EntryTags {
Type symtype = pre.memberType(sym).derefDef();
Type sym1type = pre.memberType(sym1).derefDef();
+ if (sym1.isJava()) symtype = symtype.objParamToAny();
switch (sym1type) {
case OverloadedType(Symbol[] alts, Type[] alttypes):
for (int i = 0; i < alts.length; i++) {
@@ -896,6 +897,25 @@ public class Type implements Modifiers, Kinds, TypeTags, EntryTags {
}
}
}
+ //where
+ static Map objToAnyMap = new Map() {
+ public Type apply(Type t) {
+ if (t.symbol() == Global.instance.definitions.JAVA_OBJECT_CLASS)
+ return Global.instance.definitions.ANY_TYPE();
+ else return t;
+ }
+ };
+
+ private Type objParamToAny() {
+ switch (this) {
+ case MethodType(Symbol[] params, Type restp):
+ Symbol[] params1 = objToAnyMap.map(params);
+ if (params1 == params) return this;
+ else return MethodType(params1, restp);
+ default:
+ return this;
+ }
+ }
// Set Owner ------------------------------------------------------------------