Mode.Statefulnessmodule Const : sig ... endinclude Common_axis_pos with module Const := Constinclude Mode_intf.Common_axis
with module Const := Const
and type 'd t = (Const.t, 'd Allowance.pos) mode
and type 'd hint_const := 'd Mode_intf.pos_hint_constinclude Mode_intf.Common
with module Const := Const
and type simple_error = Const.t Mode_intf.simple_error
with type 'd t = (Const.t, 'd Allowance.pos) modeval print_error : Mode_hint.pinpoint -> error -> Mode_intf.print_errorTakes a submode error accompanied by a pinpoint of the original submode, returns an explaining printer for each side. Each printer prints either a mode constant name, or "mode because ...". The function assumes pinpoint is already printed, which allows simplifying its own printing. The caller is responsible for printing pinpoint and placing the result of this function in a suitable linguistic context.
type equate_error = Mode_intf.equate_step * errortype simple_error = Const.t Mode_intf.simple_errorval to_simple_error : error -> simple_errortype 'd t = (Const.t, 'd Allowance.pos) modetype l = (Allowance.allowed * Allowance.disallowed) tLeft-only mode
type r = (Allowance.disallowed * Allowance.allowed) tRight-only mode
type lr = (Allowance.allowed * Allowance.allowed) tLeft-right mode
include Allowance.Allow_disallow with type (_, _, 'd) sided = 'd ttype (_, _, 'd) sided = 'd tval disallow_right :
('a, 'b, 'l * 'r) sided ->
('a, 'b, 'l * Allowance.disallowed) sidedDisallows on the right.
val disallow_left :
('a, 'b, 'l * 'r) sided ->
('a, 'b, Allowance.disallowed * 'r) sidedDisallows a the left.
val allow_right :
('a, 'b, 'l * Allowance.allowed) sided ->
('a, 'b, 'l * 'r) sidedGeneralizes a right-hand-side allowed to be any allowance.
val allow_left :
('a, 'b, Allowance.allowed * 'r) sided ->
('a, 'b, 'l * 'r) sidedGeneralizes a left-hand-side allowed to be any allowance.
val min : lrval max : lrval legacy : lrval newvar : unit -> ('l * 'r) tval submode :
?pp:Mode_hint.pinpoint ->
(Allowance.allowed * 'r) t ->
('l * Allowance.allowed) t ->
(unit, error) resultTakes the actual and expected mode of something, check that the actual mode is less than the expected mode. In case of error, the error is returned and no mutation is done.
The two modes should be hinted sufficently that the submode is self-evident. In particular, the two modes should be about the "same thing". See the notes How to submode for details.
val submode_err :
Mode_hint.pinpoint ->
(Allowance.allowed * 'r) t ->
('l * Allowance.allowed) t ->
unitSimilar to submode, but instead of returning an error, raise user-friendly errors directly, with pinpoint describing the thing whose actual and expected modes are being checked.
If you need more than pinpoint as the context in the error message, consider submode.
val equate : lr -> lr -> (unit, equate_error) resultval submode_exn :
?pp:Mode_hint.pinpoint ->
(Allowance.allowed * 'r) t ->
('l * Allowance.allowed) t ->
unitSimiliar to submode, but crashes the compiler if errors. Use this function if the submode is guaranteed to succeed.
val join : (Allowance.allowed * 'r) t list -> Allowance.left_only tval meet : ('l * Allowance.allowed) t list -> Allowance.right_only tval newvar_above : (Allowance.allowed * 'r) t -> ('l * 'r_) t * boolval newvar_below : ('l * Allowance.allowed) t -> ('l_ * 'r) t * boolval print : ?verbose:bool -> unit -> Format.formatter -> ('l * 'r) t -> unitval zap_to_ceil : ('l * Allowance.allowed) t -> Const.tval zap_to_floor : (Allowance.allowed * 'r) t -> Const.tval of_const : ?hint:'d Mode_intf.pos_hint_const -> Const.t -> 'd tval stateless : lrval observing : lrval stateful : lr