package octez-internal-libs

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Module Irmin.PermsSource

Types representing permissions 'perms for performing operations on a certain type 'perms t.

They are intended to be used as phantom parameters of the types that they control access to. As an example, consider the following type of references with permissions:

  module Ref : sig
    type (+'a, -'perms) t

    val create : 'a -> ('a, read_write) t
    val get : ('a, [> read ]) t -> 'a
    val set : ('a, [> write ]) t -> 'a -> unit
  end

This type allows references to be created with arbitrary read-write access. One can then create weaker views onto the reference – with access to fewer operations – by upcasting:

  let read_only t = (t :> (_, read) Ref.t)
  let write_only t = (t :> (_, write) Ref.t)

Note that the 'perms phantom type parameter should be contravariant: it's safe to discard permissions, but not to gain new ones.

Sourcemodule Read : sig ... end
Sourcemodule Write : sig ... end
Sourcemodule Read_write : sig ... end
Sourcetype read = Read.t

The type parameter of a handle with read permissions.

Sourcetype write = Write.t

The type parameter of a handle with write permissions.

Sourcetype read_write = Read_write.t

The type parameter of a handle with both read and write permissions.

OCaml

Innovation. Community. Security.