support for Scala compile-time positions;
authorwenzelm
Sat, 28 Nov 2020 15:15:53 +0100
changeset 72755 8dffbe01a3e1
parent 72754 1456c5747416
child 72756 72ac27ea12b2
support for Scala compile-time positions;
src/Pure/Tools/scala_project.scala
--- a/src/Pure/Tools/scala_project.scala	Sat Nov 28 14:25:27 2020 +0100
+++ b/src/Pure/Tools/scala_project.scala	Sat Nov 28 15:15:53 2020 +0100
@@ -62,6 +62,37 @@
       "src/HOL/Tools/Nitpick" -> Path.explode("isabelle.nitpick"))
 
 
+  /* compile-time position */
+
+  def here: Here =
+  {
+    val exn = new Exception
+    exn.getStackTrace.toList match {
+      case _ :: caller :: _ =>
+        val name = proper_string(caller.getFileName).getOrElse("")
+        val line = caller.getLineNumber
+        new Here(name, line)
+      case _ => new Here("", 0)
+    }
+  }
+
+  class Here private[Scala_Project](name: String, line: Int)
+  {
+    override def toString: String = name + ":" + line
+    def position: Position.T =
+    {
+      if (name.startsWith("<")) Position.none
+      else {
+        val suffix = "/" + name
+        isabelle_files().find(_.endsWith(suffix)) match {
+          case None => Position.none
+          case Some(file) => Position.Line_File(line, "$ISABELLE_HOME/" + file)
+        }
+      }
+    }
+  }
+
+
   /* scala project */
 
   def scala_project(project_dir: Path, symlinks: Boolean = false)