diff options
author | Paul Phillips <paulp@improving.org> | 2010-10-02 22:43:10 +0000 |
---|---|---|
committer | Paul Phillips <paulp@improving.org> | 2010-10-02 22:43:10 +0000 |
commit | 06aa1c9eff49d5190e82a72a876d7b3bd706d6d4 (patch) | |
tree | 4c38f2559c839ba297060a48023d69550c5d107e /test/files/pos/testCoercionThis.scala | |
parent | 256aca612204f1316e5281af6d10a14300d58ad1 (diff) | |
download | scala-06aa1c9eff49d5190e82a72a876d7b3bd706d6d4.tar.gz scala-06aa1c9eff49d5190e82a72a876d7b3bd706d6d4.tar.bz2 scala-06aa1c9eff49d5190e82a72a876d7b3bd706d6d4.zip |
Sorting through the tests in pending from oldes...
Sorting through the tests in pending from oldest to newest because I
don't believe in having useless appendages. The verdict on the oldest
fifteen tests is: 15/15 are fixed. Many were already in files under a
different name. I moved a few and deleted the rest. Fun fact of the
day: apparently there was a time when to call into java varargs with no
arguments you might have to write something like:
getClass().getMethod("getCount", Array[java.lang.Class[T] forSome { type T }]())
On this basis I retract any complaints I've ever had about anything.
There is one question mark outlined in pos/testCoercionThis.scala, a
file formerly called pos/moors.scala and therefore... review by moors.
Diffstat (limited to 'test/files/pos/testCoercionThis.scala')
-rw-r--r-- | test/files/pos/testCoercionThis.scala | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/test/files/pos/testCoercionThis.scala b/test/files/pos/testCoercionThis.scala new file mode 100644 index 0000000000..5631b33306 --- /dev/null +++ b/test/files/pos/testCoercionThis.scala @@ -0,0 +1,19 @@ +object Test { + implicit def foo2bar(foo: Foo): Bar = foo.bar + + class Foo(val bar: Bar) { + def testCoercion = { + val a: this.type = this + a.baz /* here, foo2bar is inferred by the compiler, as expected */ + } + // def testCoercionThis0 = baz + // --> error: not found: value baz + // PP: is that something we really want to work? Seems like sketchville. + // + // These work, so I moved this out of pending. + def testCoercionThis1 = this.baz + def testCoercionThis2 = (this: Foo).baz + } + + class Bar { def baz = System.out.println("baz") } +} |