summaryrefslogtreecommitdiff
path: root/src/compiler/scala/tools/nsc/symtab/classfile/ClassfileParser.scala
diff options
context:
space:
mode:
authorPaul Phillips <paulp@improving.org>2010-11-12 00:07:37 +0000
committerPaul Phillips <paulp@improving.org>2010-11-12 00:07:37 +0000
commit91eff8e6d903a9eab2bc83c120774d623df5ad7d (patch)
tree23b15f42d230452d5f0ac0b7ff6ee9f96766a3d5 /src/compiler/scala/tools/nsc/symtab/classfile/ClassfileParser.scala
parent46a921df8152d2535cca577132a2fe323a57ca88 (diff)
downloadscala-91eff8e6d903a9eab2bc83c120774d623df5ad7d.tar.gz
scala-91eff8e6d903a9eab2bc83c120774d623df5ad7d.tar.bz2
scala-91eff8e6d903a9eab2bc83c120774d623df5ad7d.zip
Half of an implementation of sealedness for jav...
Half of an implementation of sealedness for java enums. Since it's only half it's behind -Xexperimental, but it works like a charm for the half where it works (that being compiling against bytecode.) Need input on how to approach the source half. References ticket #2442. Review by moors.
Diffstat (limited to 'src/compiler/scala/tools/nsc/symtab/classfile/ClassfileParser.scala')
-rw-r--r--src/compiler/scala/tools/nsc/symtab/classfile/ClassfileParser.scala24
1 files changed, 19 insertions, 5 deletions
diff --git a/src/compiler/scala/tools/nsc/symtab/classfile/ClassfileParser.scala b/src/compiler/scala/tools/nsc/symtab/classfile/ClassfileParser.scala
index 2c47239a92..a051177a87 100644
--- a/src/compiler/scala/tools/nsc/symtab/classfile/ClassfileParser.scala
+++ b/src/compiler/scala/tools/nsc/symtab/classfile/ClassfileParser.scala
@@ -603,14 +603,28 @@ abstract class ClassfileParser {
if ((sflags & PRIVATE) != 0L && !global.settings.XO.value) {
in.skip(4); skipAttributes()
} else {
- val name = pool.getName(in.nextChar)
- val info = pool.getType(in.nextChar)
- val sym = getOwner(jflags)
- .newValue(NoPosition, name).setFlag(sflags)
- sym.setInfo(if ((jflags & JAVA_ACC_ENUM) == 0) info else ConstantType(Constant(sym)))
+ val name = pool.getName(in.nextChar)
+ val info = pool.getType(in.nextChar)
+ val sym = getOwner(jflags).newValue(NoPosition, name).setFlag(sflags)
+ val isEnum = (jflags & JAVA_ACC_ENUM) != 0
+
+ sym setInfo {
+ if (isEnum) ConstantType(Constant(sym))
+ else info
+ }
setPrivateWithin(sym, jflags)
parseAttributes(sym, info)
getScope(jflags).enter(sym)
+
+ // sealed java enums (experimental)
+ if (isEnum && opt.experimental) {
+ // need to give singleton type
+ sym setInfo info.narrow
+ if (!sym.superClass.isSealed)
+ sym.superClass setFlag (SEALED | ABSTRACT)
+
+ sym.superClass addChild sym
+ }
}
}