[MLton-commit] r6611
    Matthew Fluet 
    fluet at mlton.org
       
    Sat May 10 04:42:29 PDT 2008
    
    
  
Refactor to unify treatment of top-level suffix and top-level handler.
----------------------------------------------------------------------
U   mlton/trunk/basis-library/mlton/exit.sml
U   mlton/trunk/basis-library/mlton/mlton.sml
----------------------------------------------------------------------
Modified: mlton/trunk/basis-library/mlton/exit.sml
===================================================================
--- mlton/trunk/basis-library/mlton/exit.sml	2008-05-09 11:23:42 UTC (rev 6610)
+++ mlton/trunk/basis-library/mlton/exit.sml	2008-05-10 11:42:27 UTC (rev 6611)
@@ -28,7 +28,7 @@
 
       fun exit (status: Status.t): 'a =
          if !exiting
-            then raise Fail "exit"
+            then raise Fail "MLton.Exit.exit"
          else
             let
                val _ = exiting := true
@@ -37,8 +37,28 @@
                if 0 <= i andalso i < 256
                   then (let open Cleaner in clean atExit end
                         ; halt status
-                        ; raise Fail "exit")
-               else raise Fail (concat ["exit must have 0 <= status < 256: saw ",
-                                        Int.toString i])
+                        ; raise Fail "MLton.Exit.exit")
+               else raise Fail (concat ["MLton.Exit.exit(", Int.toString i, "): ",
+                                        "exit must have 0 <= status < 256"])
             end
+
+      local
+         val message = PrimitiveFFI.Stdio.print
+         fun 'a wrapSuffix (suffix: unit -> unit) () : 'a =
+            (suffix ()
+             ; message "Top-level suffix returned.\n"
+             ; exit Status.failure)
+            handle _ => (message "Top-level suffix raised exception.\n"
+                         ; halt Status.failure
+                         ; raise Fail "MLton.Exit.wrapSuffix")
+      in
+         val getTopLevelSuffix = Primitive.TopLevel.getSuffix
+         val setTopLevelSuffix = Primitive.TopLevel.setSuffix o wrapSuffix
+         fun 'a defaultTopLevelSuffix ((): unit): 'a =
+            wrapSuffix (fn () => exit Status.success) ()
+         fun 'a topLevelSuffix ((): unit) : 'a =
+            (getTopLevelSuffix () ()
+             ; raise Fail "MLton.Exit.topLevelSuffix")
+      end
+
    end
Modified: mlton/trunk/basis-library/mlton/mlton.sml
===================================================================
--- mlton/trunk/basis-library/mlton/mlton.sml	2008-05-09 11:23:42 UTC (rev 6610)
+++ mlton/trunk/basis-library/mlton/mlton.sml	2008-05-10 11:42:27 UTC (rev 6611)
@@ -150,8 +150,7 @@
 
 val _ = 
    (Primitive.TopLevel.setHandler MLtonExn.defaultTopLevelHandler
-    ; Primitive.TopLevel.setSuffix 
-      (fn () => MLtonProcess.exit MLtonProcess.Status.success))
+    ; Primitive.TopLevel.setSuffix Exit.defaultTopLevelSuffix)
 end
 
 (* Patch OS.FileSys.tmpName to use mkstemp. *)
    
    
More information about the MLton-commit
mailing list