summaryrefslogtreecommitdiff
path: root/test/scaladoc/javascript
diff options
context:
space:
mode:
authorJason Zaugg <jzaugg@gmail.com>2013-01-21 10:45:36 +0100
committerJason Zaugg <jzaugg@gmail.com>2013-01-21 11:12:57 +0100
commitf6168b8a4d661985b0fb4d6d3cbba256bfc69607 (patch)
tree386c6695d03fb0b3787ead0a4aececc47a24fa58 /test/scaladoc/javascript
parent6f72ed85c3882d2a8c824a41e6e42d7f33b8d1d6 (diff)
downloadscala-f6168b8a4d661985b0fb4d6d3cbba256bfc69607.tar.gz
scala-f6168b8a4d661985b0fb4d6d3cbba256bfc69607.tar.bz2
scala-f6168b8a4d661985b0fb4d6d3cbba256bfc69607.zip
SI-6231 Report unsupported free var capture by a trait.
If a class nested in a trait captures a free variable from the enclosing scope of the trait, the transformation to add that variable to the `init` method of the trait implementation class happens *after* the abstract trait interface has been extracted. This would lead to a crash when trying to find the corresponding interface method. This commit detects this situation and reports an implementation restriction. The enclosed test case shows a workaround. To lift this restriction, LambdaLifter should add the getters and make sure they end up in the trait interface. Looks like Martin tried this once: // LambdaLift.scala // // Disabled attempt to to add getters to freeParams // this does not work yet. Problem is that local symbols need local names // and references to local symbols need to be transformed into // method calls to setters. // def paramGetter(param: Symbol): Tree = { // val getter = param.newGetter setFlag TRANS_FLAG resetFlag PARAMACCESSOR // mark because we have to add them to interface // sym.info.decls.enter(getter) // val rhs = Select(gen.mkAttributedThis(sym), param) setType param.tpe // DefDef(getter, rhs) setPos tree.pos setType NoType // } // val newDefs = if (sym.isTrait) freeParams ::: (ps map paramGetter) else freeParams
Diffstat (limited to 'test/scaladoc/javascript')
0 files changed, 0 insertions, 0 deletions