From f205501be80001855b06d64c4260adafe6dc4417 Mon Sep 17 00:00:00 2001 From: Gilles Dubochet Date: Tue, 9 Jun 2009 13:22:01 +0000 Subject: Added a series of pending test cases. --- test/pending/pos/bug1957.scala | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 test/pending/pos/bug1957.scala (limited to 'test/pending/pos/bug1957.scala') diff --git a/test/pending/pos/bug1957.scala b/test/pending/pos/bug1957.scala new file mode 100644 index 0000000000..62800524eb --- /dev/null +++ b/test/pending/pos/bug1957.scala @@ -0,0 +1,38 @@ +object Test { + abstract class Settings {} + + abstract class Grist + { self => + type settingsType <: Settings + type moduleType <: Module {type settingsType = self.settingsType} + val module: moduleType + } + + abstract class Tool + { self => + type settingsType <: Settings + type moduleType = Module { type settingsType = self.settingsType } + type gristType = Grist { type moduleType <: self.moduleType; type settingsType <: self.settingsType } + + def inputGrist: List[gristType] + } + + abstract class Module + { self => + type settingsType <: Settings + final type commonModuleType = Module {type settingsType = self.settingsType} + type selfType >: self.type <: commonModuleType + + // BTW: if we use the commented out type declarations, the code compiles successfully + // type gristType = Grist {type settingsType <: self.settingsType; type moduleType <: commonModuleType } + + val tools: List[Tool {type settingsType = self.settingsType}] + + protected def f: List[commonModuleType] = + { + val inputGrists = tools.flatMap(_.inputGrist) // val inputGrists: List[gristType] = + inputGrists.map(_.module) + } + + } +} \ No newline at end of file -- cgit v1.2.3