Why3 Standard Library index


A possibly null, yet safe, value

The OCaml driver does optimize this into the identity.

To permit the implementation of eq_null, null is implemented as a heap-allocated value in OCaml, e.g., Obj.magic [|0|].

module Null

  type null = int

  type t_model 'a = Null null | Value 'a

  type t 'a = abstract { v: t_model 'a }

  let ghost predicate is_null (t: t 'a) =
    match t.v with Null _ -> true | Value _ -> false end

  val create_null () : t 'a
    ensures { is_null result }

  val eq_null (n x: t 'a) : bool
    requires { is_null n }
    ensures  { result <-> x.v = n.v }

  val create (x: 'a) : t 'a
    ensures { result.v = Value x }

  val get (t: t 'a) : 'a
    requires { not (is_null t) }
    ensures  { t.v = Value result }

end

Generated by why3doc 1.7.2