summaryrefslogtreecommitdiff
path: root/test/files/pos/sammy_scope.scala
diff options
context:
space:
mode:
authorAdriaan Moors <adriaan.moors@typesafe.com>2013-10-03 23:02:27 -0700
committerAdriaan Moors <adriaan.moors@typesafe.com>2013-10-04 10:55:17 -0700
commit67062db57c1abef88e0049dac5d82d4f13375a48 (patch)
tree69cebe4522d71b8c9241ab887a486382106a6c3e /test/files/pos/sammy_scope.scala
parent657e85fe2412cdadc5ee9dc348159b32dcdfcba7 (diff)
downloadscala-67062db57c1abef88e0049dac5d82d4f13375a48.tar.gz
scala-67062db57c1abef88e0049dac5d82d4f13375a48.tar.bz2
scala-67062db57c1abef88e0049dac5d82d4f13375a48.zip
Single Abstract Method support: synthesize SAMs
Under `-Xexperimental`, `typedFunction` invokes `synthesizeSAMFunction` when the expected type for the function literal (`pt`) is not the built-in `FunctionN` type of the expected arity, but `pt` does have a SAM with the expected number of arguments. PS: We'll require `import language.sam` instead of `-Xexperimental`, as soon as the SIP is ready and there are more tests.
Diffstat (limited to 'test/files/pos/sammy_scope.scala')
-rw-r--r--test/files/pos/sammy_scope.scala8
1 files changed, 8 insertions, 0 deletions
diff --git a/test/files/pos/sammy_scope.scala b/test/files/pos/sammy_scope.scala
new file mode 100644
index 0000000000..8f1fe7058e
--- /dev/null
+++ b/test/files/pos/sammy_scope.scala
@@ -0,0 +1,8 @@
+// test synthesizeSAMFunction: scope hygiene
+abstract class SamFun[T1, R] { self =>
+ def apply(v1: T1): R
+
+ // this should type check, as the apply ref is equivalent to self.apply
+ // it shouldn't resolve to the sam's apply that's synthesized (that wouldn't type check, hence the pos test)
+ def compose[A](g: SamFun[A, T1]): SamFun[A, R] = { x => apply(g(x)) }
+} \ No newline at end of file