package coq-core

  1. Overview
  2. Docs
The Coq Proof Assistant -- Core Binaries and Tools

Install

Dune Dependency

Authors

Maintainers

Sources

coq-8.19.2.tar.gz
md5=5d1187d5e44ed0163f76fb12dabf012e
sha512=91bc81530fa4f6498961583ad51eac5001f139881788b88e360a866ad8e2a6e2c5bce86d1a580ab4cd4782bf49d48318767df82471ce33ba3ac143e5569ad33c

doc/coq-core.clib/Exninfo/index.html

Module ExninfoSource

Additional information worn by exceptions.

Sourcetype 'a t

Information containing a given type.

Sourcetype info

All information

Sourcetype iexn = exn * info

Information-wearing exceptions

Sourceval make : unit -> 'a t

Create a new piece of information.

Sourceval null : info

No information

Sourceval add : info -> 'a t -> 'a -> info

Add information to an exception.

Sourceval get : info -> 'a t -> 'a option

Get information worn by an exception. Returns None if undefined.

Sourceval info : exn -> info

Retrieve the information of the last exception raised.

Sourcetype backtrace
Sourceval get_backtrace : info -> backtrace option

get_backtrace info does get the backtrace associated to info

Sourceval backtrace_to_string : backtrace -> string

backtrace_to_string info does get the backtrace associated to info

Sourceval record_backtrace : bool -> unit
Sourceval capture : exn -> iexn

Add the current backtrace information and other meta-data to the given exception.

The intended use case is to re-raise an exception while preserving the meta-data:


try foo
with
| Bar -> bar
| My_exn _ as exn ->
  let (exn, info) = Exninfo.capture err in
  ...
  let info = ... in
  Exninfo.iraise (exn, info)

| exn when CErrors.noncritical exn ->
  let iexn = Exninfo.capture err in
  ...
  Exninfo.iraise iexn

where baz should re-raise using iraise below.

WARNING: any intermediate code between the with and the handler may modify the backtrace. Yes, that includes when clauses. Ideally, what you should do is something like:


try foo
with exn when CErrors.noncritical exn ->
  let (err, info) = Exninfo.capture exn in
  match err with
  | exception Bar -> ...
  | err -> ...

I admit that's a bit heavy, but there is not much to do...

Sourceval iraise : iexn -> 'a

Raise the given enriched exception.

Sourceval reify : unit -> info
OCaml

Innovation. Community. Security.