persistent storage of imported_sources;
authorwenzelm
Sun, 01 Oct 2017 20:50:26 +0200
changeset 66744 fec1504e5f03
parent 66743 ff05d922bc34
child 66745 e7ac579b883c
persistent storage of imported_sources;
src/Pure/Thy/sessions.scala
src/Pure/Tools/build.scala
--- a/src/Pure/Thy/sessions.scala	Sun Oct 01 17:59:26 2017 +0200
+++ b/src/Pure/Thy/sessions.scala	Sun Oct 01 20:50:26 2017 +0200
@@ -114,8 +114,8 @@
     loaded_theories: Graph[String, Outer_Syntax] = Graph.string,
     known: Known = Known.empty,
     overall_syntax: Outer_Syntax = Outer_Syntax.empty,
+    imported_sources: List[(Path, SHA1.Digest)] = Nil,
     sources: List[(Path, SHA1.Digest)] = Nil,
-    imported_sources: List[(Path, SHA1.Digest)] = Nil,
     session_graph: Graph_Display.Graph = Graph_Display.empty_graph,
     errors: List[String] = Nil,
     imports: Option[Base] = None)
@@ -148,7 +148,12 @@
   {
     def is_empty: Boolean = session_bases.isEmpty
     def apply(name: String): Base = session_bases(name)
-    def sources(name: String): List[SHA1.Digest] = session_bases(name).sources.map(_._2)
+
+    def imported_sources(name: String): List[SHA1.Digest] =
+      session_bases(name).imported_sources.map(_._2)
+
+    def sources(name: String): List[SHA1.Digest] =
+      session_bases(name).sources.map(_._2)
 
     def errors: List[String] =
       (for {
@@ -297,8 +302,8 @@
                 loaded_theories = thy_deps.loaded_theories,
                 known = known,
                 overall_syntax = overall_syntax,
+                imported_sources = check_sources(imported_files),
                 sources = check_sources(session_files),
-                imported_sources = check_sources(imported_files),
                 session_graph = session_graph,
                 errors = thy_deps.errors ::: sources_errors,
                 imports = Some(imports_base))
@@ -810,11 +815,12 @@
       List(session_name, session_timing, command_timings, ml_statistics, task_statistics, errors)
 
     // Build.Session_Info
+    val imported_sources = SQL.Column.string("imported_sources")
     val sources = SQL.Column.string("sources")
     val input_heaps = SQL.Column.string("input_heaps")
     val output_heap = SQL.Column.string("output_heap")
     val return_code = SQL.Column.int("return_code")
-    val build_columns = List(sources, input_heaps, output_heap, return_code)
+    val build_columns = List(imported_sources, sources, input_heaps, output_heap, return_code)
 
     val table = SQL.Table("isabelle_session_info", build_log_columns ::: build_columns)
   }
@@ -903,10 +909,11 @@
           stmt.bytes(4) = Properties.compress(build_log.ml_statistics)
           stmt.bytes(5) = Properties.compress(build_log.task_statistics)
           stmt.bytes(6) = Build_Log.compress_errors(build_log.errors)
-          stmt.string(7) = cat_lines(build.sources)
-          stmt.string(8) = cat_lines(build.input_heaps)
-          stmt.string(9) = build.output_heap getOrElse ""
-          stmt.int(10) = build.return_code
+          stmt.string(7) = cat_lines(build.imported_sources)
+          stmt.string(8) = cat_lines(build.sources)
+          stmt.string(9) = cat_lines(build.input_heaps)
+          stmt.string(10) = build.output_heap getOrElse ""
+          stmt.int(11) = build.return_code
           stmt.execute()
         })
       }
@@ -928,19 +935,35 @@
       Build_Log.uncompress_errors(read_bytes(db, name, Session_Info.errors))
 
     def read_build(db: SQL.Database, name: String): Option[Build.Session_Info] =
-      db.using_statement(Session_Info.table.select(Session_Info.build_columns,
-        Session_Info.session_name.where_equal(name)))(stmt =>
-      {
-        val res = stmt.execute_query()
-        if (!res.next()) None
-        else {
-          Some(
-            Build.Session_Info(
-              split_lines(res.string(Session_Info.sources)),
-              split_lines(res.string(Session_Info.input_heaps)),
-              res.string(Session_Info.output_heap) match { case "" => None case s => Some(s) },
-              res.int(Session_Info.return_code)))
-        }
-      })
+    {
+      val result0 =
+        db.using_statement(Session_Info.table.select(Session_Info.build_columns.tail,
+          Session_Info.session_name.where_equal(name)))(stmt =>
+        {
+          val res = stmt.execute_query()
+          if (!res.next()) None
+          else {
+            Some(
+              Build.Session_Info(Nil,
+                split_lines(res.string(Session_Info.sources)),
+                split_lines(res.string(Session_Info.input_heaps)),
+                res.string(Session_Info.output_heap) match { case "" => None case s => Some(s) },
+                res.int(Session_Info.return_code)))
+          }
+        })
+      result0.map(info =>
+        info.copy(imported_sources =
+          try {
+            db.using_statement(Session_Info.table.select(List(Session_Info.imported_sources),
+              Session_Info.session_name.where_equal(name)))(stmt =>
+            {
+              val res = stmt.execute_query()
+              if (!res.next) Nil else split_lines(res.string(Session_Info.imported_sources))
+            })
+          } // column "imported_sources" could be missing
+          catch { case _: java.sql.SQLException => Nil }
+        )
+      )
+    }
   }
 }
--- a/src/Pure/Tools/build.scala	Sun Oct 01 17:59:26 2017 +0200
+++ b/src/Pure/Tools/build.scala	Sun Oct 01 20:50:26 2017 +0200
@@ -24,6 +24,7 @@
   /* persistent build info */
 
   sealed case class Session_Info(
+    imported_sources: List[String],
     sources: List[String],
     input_heaps: List[String],
     output_heap: Option[String],
@@ -380,6 +381,9 @@
         verbose = verbose, list_files = list_files, check_keywords = check_keywords,
         global_theories = full_sessions.global_theories).check_errors
 
+    def imported_sources_stamp(name: String): List[String] =
+      deps.imported_sources(name).map(_.toString).sorted
+
     def sources_stamp(name: String): List[String] =
       (selected_sessions(name).meta_digest :: deps.sources(name)).map(_.toString).sorted
 
@@ -501,7 +505,12 @@
                       parse_session_info(
                         command_timings = true, ml_statistics = true, task_statistics = true),
                   build =
-                    Session_Info(sources_stamp(name), input_heaps, heap_stamp, process_result.rc)))
+                    Session_Info(
+                      imported_sources_stamp(name),
+                      sources_stamp(name),
+                      input_heaps,
+                      heap_stamp,
+                      process_result.rc)))
             }
 
             // messages