diff options
Diffstat (limited to 'test/disabled/presentation/find-trees')
-rw-r--r-- | test/disabled/presentation/find-trees/FindTrees.scala | 51 | ||||
-rw-r--r-- | test/disabled/presentation/find-trees/src/InteractiveTest.scala | 36 |
2 files changed, 87 insertions, 0 deletions
diff --git a/test/disabled/presentation/find-trees/FindTrees.scala b/test/disabled/presentation/find-trees/FindTrees.scala new file mode 100644 index 0000000000..63272948a9 --- /dev/null +++ b/test/disabled/presentation/find-trees/FindTrees.scala @@ -0,0 +1,51 @@ +import scala.tools.nsc.interactive.tests.InteractiveTest +import scala.tools.nsc.util.Position + + +/** Example interactive test that does everything by hand. It would be much simpler + * to just add the markers in the test file. This test shows how to drive + * the presentation compiler manually. + */ +object Test extends InteractiveTest { + + def askForPos(pos: Position) { + import compiler._ + val response = new Response[Tree] + + println("asking position at %d:%d".format(pos.line, pos.column)) + compiler.askTypeAt(pos, response) + response.get match { + case Left(EmptyTree) => + println("error retrieving tree at %d:%d".format(pos.line, pos.column)) + case Left(t) => + println("retrieved tree: " + t) + } + println(this.reporter.infos.mkString("\n")) + } + + // You can enable settings for the presentation compiler here + // but don't leave them in the nightly build since the log will most likely + // contain absolute paths + +// settings.YpresentationDebug.value = true +// settings.YpresentationVerbose.value = true + + override def runTest { + import compiler._ + val src = sourceFiles(0) // only one under src/ + //val pos = rangePos(src, 426, 426, 433) + val pos1 = src.position(19, 15) // this is an offset position + + // reload is issued already by the framework, so we don't need to do it, but it doesn't hurt + val reload = new Response[Unit] + compiler.askReload(List(src), reload) + reload.get // it's important to let reload finish before asking other things. + + // re-enable when positions in the primary constructor are handled reliably +// askForPos(pos) + println("=" * 20) + askForPos(pos1) + + compiler.askShutdown() + } +} diff --git a/test/disabled/presentation/find-trees/src/InteractiveTest.scala b/test/disabled/presentation/find-trees/src/InteractiveTest.scala new file mode 100644 index 0000000000..a1a3f96ee0 --- /dev/null +++ b/test/disabled/presentation/find-trees/src/InteractiveTest.scala @@ -0,0 +1,36 @@ +package scala.tools.nsc.interactive +package tests + +import scala.tools.nsc.Settings +import scala.tools.nsc.reporters.StoreReporter +import scala.tools.nsc.util.{BatchSourceFile, SourceFile, Position} +import scala.tools.nsc.io._ + +/** A base class for writing interactive compiler tests. + * + * @author Iulian Dragos + * + */ +abstract class InteractiveTest { + + val settings = new Settings + val reporter= new StoreReporter + + settings.YpresentationDebug.value = true + lazy val compiler: CompilerControl = new Global(settings, reporter) + + def sources(filename: String*): Seq[SourceFile] = + filename map source + + def source(filename: String) = new BatchSourceFile(AbstractFile.getFile(filename)) + + def pos(filename: String, line: Int, col: Int): Position = + source(filename).position(line, col) + + def runTest: Unit + + def main(args: Array[String]) { + runTest + } +} + |