1995-08-09 08:06:35 -07:00
|
|
|
(***********************************************************************)
|
|
|
|
(* *)
|
1996-04-30 07:53:58 -07:00
|
|
|
(* Objective Caml *)
|
1995-08-09 08:06:35 -07:00
|
|
|
(* *)
|
|
|
|
(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)
|
|
|
|
(* *)
|
1996-04-30 07:53:58 -07:00
|
|
|
(* Copyright 1996 Institut National de Recherche en Informatique et *)
|
1999-11-17 10:59:06 -08:00
|
|
|
(* en Automatique. All rights reserved. This file is distributed *)
|
|
|
|
(* under the terms of the GNU Library General Public License. *)
|
1995-08-09 08:06:35 -07:00
|
|
|
(* *)
|
|
|
|
(***********************************************************************)
|
|
|
|
|
|
|
|
(* $Id$ *)
|
|
|
|
|
2001-06-19 03:04:04 -07:00
|
|
|
(* Module [Printexc]: facilities for printing exceptions *)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
2001-06-19 03:04:04 -07:00
|
|
|
val to_string : exn -> string
|
|
|
|
(* [Printexc.to_string e] returns a string representation of
|
|
|
|
the exception [e]. *)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
|
|
|
val print: ('a -> 'b) -> 'a -> 'b
|
2001-06-19 03:04:04 -07:00
|
|
|
(* [Printexc.print fn x] applies [fn] to [x] and returns the result.
|
|
|
|
If the evaluation of [fn x] raises any exception, the
|
|
|
|
name of the exception is printed on standard error output,
|
|
|
|
and the exception is raised again.
|
|
|
|
The typical use is to catch and report exceptions that
|
|
|
|
escape a function application. *)
|
1997-06-06 07:54:09 -07:00
|
|
|
|
2001-06-19 03:04:04 -07:00
|
|
|
val catch: ('a -> 'b) -> 'a -> 'b
|
|
|
|
(* [Printexc.catch fn x] is similar to [Printexc.print], but
|
|
|
|
aborts the program with exit code 2 after printing the
|
|
|
|
uncaught exception. This function is deprecated: the runtime
|
|
|
|
system is now able to print uncaught exceptions as precisely
|
|
|
|
as [Printexc.catch] does. Moreover, calling [Printexc.catch]
|
|
|
|
makes it harder to track the location of the exception
|
|
|
|
using the debugger or the stack backtrace facility.
|
|
|
|
So, do not use [Printexc.catch] in new code. *)
|