proper treatment of timeout: <= 0 means already timed out, but for $KODKODI/bin/kodkodi it would mean NO timeout;
authorwenzelm
Sat, 22 Aug 2020 14:56:33 +0200
changeset 72191 d436ba9ac9aa
parent 72190 8009c4b5db5e
child 72192 07635a1b6fd2
proper treatment of timeout: <= 0 means already timed out, but for $KODKODI/bin/kodkodi it would mean NO timeout;
src/HOL/Tools/Nitpick/kodkod.ML
--- a/src/HOL/Tools/Nitpick/kodkod.ML	Sat Aug 22 14:48:00 2020 +0200
+++ b/src/HOL/Tools/Nitpick/kodkod.ML	Sat Aug 22 14:56:33 2020 +0200
@@ -981,9 +981,6 @@
    is partly due to the JVM and partly due to the ML "bash" function. *)
 val fudge_ms = 250
 
-fun milliseconds_until_deadline deadline =
-  Int.max (0, Time.toMilliseconds (deadline - Time.now ()) - fudge_ms)
-
 fun uncached_solve_any_problem overlord deadline max_threads max_solutions
                                problems =
   let
@@ -996,9 +993,12 @@
     val triv_js = filter_out (AList.defined (op =) indexed_problems)
                              (0 upto length problems - 1)
     val reindex = fst o nth indexed_problems
+
+    val timeout = Time.toMilliseconds (deadline - Time.now ()) - fudge_ms
   in
     if null indexed_problems then
       Normal ([], triv_js, "")
+    else if timeout <= 0 then TimedOut triv_js
     else
       let
         val (serial_str, temp_dir) = serial_string_and_temporary_dir overlord
@@ -1016,14 +1016,12 @@
           else List.app (ignore o try File.rm) [in_path, out_path, err_path]
       in
         let
-          val ms = milliseconds_until_deadline deadline
           val outcome =
             let
               val code =
                 Isabelle_System.bash ("cd " ^ Bash.string temp_dir ^ ";\n\
                       \\"$KODKODI/bin/kodkodi\"" ^
-                      (if ms >= 0 then " -max-msecs " ^ string_of_int ms
-                       else "") ^
+                      (" -max-msecs " ^ string_of_int timeout) ^
                       (if max_solutions > 1 then " -solve-all" else "") ^
                       " -max-solutions " ^ string_of_int max_solutions ^
                       (if max_threads > 0 then