tuned;
authorwenzelm
Sat, 23 Jun 2018 17:05:59 +0200
changeset 68487 3d710aa23846
parent 68486 6984a55f3cba
child 68489 56034bd1b5f6
tuned;
src/Pure/Tools/build.scala
--- a/src/Pure/Tools/build.scala	Sat Jun 23 14:23:53 2018 +0200
+++ b/src/Pure/Tools/build.scala	Sat Jun 23 17:05:59 2018 +0200
@@ -67,14 +67,18 @@
     def make_session_timing(sessions: Sessions.Structure, timing: Map[String, Double])
       : Map[String, Double] =
     {
+      val maximals = sessions.build_graph.maximals.toSet
       def desc_timing(name: String): Double =
       {
-        val g = sessions.build_graph.restrict(sessions.build_descendants(List(name)).toSet)
-        (0.0 :: g.maximals.flatMap(desc => {
-          val ps = g.all_preds(List(desc))
-          if (ps.exists(p => timing.get(p).isEmpty)) None
-          else Some(ps.map(timing(_)).sum)
-        })).max
+        if (maximals.contains(name)) timing(name)
+        else {
+          val g = sessions.build_graph.restrict(sessions.build_descendants(List(name)).toSet)
+          (0.0 :: g.maximals.flatMap(desc => {
+            val ps = g.all_preds(List(desc))
+            if (ps.exists(p => timing.get(p).isEmpty)) None
+            else Some(ps.map(timing(_)).sum)
+          })).max
+        }
       }
       timing.keySet.iterator.map(name => (name -> desc_timing(name))).toMap.withDefaultValue(0.0)
     }