meta_digest without accidental source positions (amending 1544e61e5314): avoid spurious rebuild of unrelated sessions after editing ROOT;
authorwenzelm
Tue, 25 Apr 2017 21:31:28 +0200
changeset 65580 66351f79c295
parent 65579 52eafedaf196
child 65581 baf96277ee76
child 65583 8d53b3bebab4
child 65588 b0d8d97198b3
meta_digest without accidental source positions (amending 1544e61e5314): avoid spurious rebuild of unrelated sessions after editing ROOT;
src/Pure/Thy/sessions.scala
--- a/src/Pure/Thy/sessions.scala	Tue Apr 25 17:10:17 2017 +0100
+++ b/src/Pure/Thy/sessions.scala	Tue Apr 25 21:31:28 2017 +0200
@@ -502,6 +502,10 @@
       theories: List[(List[Options.Spec], List[((String, Position.T), Boolean)])],
       files: List[String],
       document_files: List[(String, String)]) extends Entry
+    {
+      def theories_no_position: List[(List[Options.Spec], List[(String, Boolean)])] =
+        theories.map({ case (a, b) => (a, b.map({ case ((c, _), d) => (c, d) })) })
+    }
 
     private val chapter: Parser[Chapter] =
     {
@@ -583,8 +587,8 @@
             entry.document_files.map({ case (s1, s2) => (Path.explode(s1), Path.explode(s2)) })
 
           val meta_digest =
-            SHA1.digest((entry_chapter, name, entry.parent, entry.options,
-              entry.imports, entry.theories, entry.files, entry.document_files).toString)
+            SHA1.digest((entry_chapter, name, entry.parent, entry.options, entry.imports,
+              entry.theories_no_position, entry.files, entry.document_files).toString)
 
           val info =
             Info(name, entry_chapter, select, entry.pos, entry.groups,