Module Changeset_lib.Make
Parameters
Signature
Types
- type source- = I.source
- The type of the original record type. 
Exceptions
Binding
- type binding
- The type of bindings used by the - put_changesfunction.
Errors
Changeset
- val empty : t
- The empty changeset. 
- val is_empty : t ‑> Base.bool
- is_empty treturns true if the changes is empty, false otherwise.
- val is_valid : t ‑> Base.bool
- is_valid treturns- trueif the changeset- tdoes not contain any error or- falseotherwise.
- val from_record : source ‑> t
- from_record xreturns a changeset in which all the elements in- xare loaded as changes.
- val put_change : 'a label ‑> 'a ‑> t ‑> t
- put_change l x tputs a change associating the label- lwith value- xin the changeset- t.
- val put_changes : binding Base.list ‑> t ‑> t
- put_change bs tapplies- put_changeto the list of binding- bsin the changeset- tfrom left to right.
- val mem_label : _ label ‑> t ‑> Base.bool
- mem_label l treturns- trueif there is a binding of- lin the changeset- tor- falseotherwise.
- val mem_error : error ‑> t ‑> Base.bool
- mem_error e treturns- trueif the error belongs to the changeset- tor- falseotherwise.
- val find : 'a label ‑> t ‑> 'a Base.option
- find l treturns the value associated with the label- lin the changeset- twrapped in an option value. It returns- Noneif the label- lis unbound in- t.
- val find_exn : 'a label ‑> t ‑> 'a
- find l treturns the value associated with label- lin the changeset- t. It raises the exception- Not_foundif the label- lis unbound in- t.
- val apply : t ‑> (source, t) Base.Result.t
- apply treturns:- Ok xwhere- xis a value of type- sourceif the changeset- tis valid and all the labels are present in the changes of- t.
- Error t'otherwise, where- t'corresponds to the changeset- tif it was not valid, or- texpanded with an- error- (l => "is missing")if the changeset was valid but a- label- lwas not found.
 
- val apply_exn : t ‑> source
- apply treturns a value of type- sourceif the changeset- tis valid and all the labels are present in the changes of- t. It raises the exception- Invalid_changesotherwise.
- val show_errors : t ‑> Base.string
- show_errors treturns a string in the json format of the errors contained in the changeset- t.
Validations
- val validate_change : 'a label ‑> ('a ‑> Base.string Base.list) ‑> t ‑> t
- validate_change l f tapplies- fto the value associated with label- lin the changeset- tand adds the list of error messages returned to the errors of the changeset- t, all being indexed by label- l. If there is no binding for label- lin changeset- t, the validation is not applied.
- val require : 'a label ‑> ?message:Base.string ‑> t ‑> t
- require l tvalidates that there is a binding of- lin the changeset- t. If not, the error- messageindexed by the label- lis added to the changeset- t. Default error message is- "is required".
- type length_opt=- [- |- `is of Base.int- |- `min of Base.int- |- `max of Base.int- ]
- Options for length validations are the ones above where: - `is n: the length must be exactly- n.
- `min n: the length must be greater than or equal to- n.
- `max n: the length must be less than or equal to- n.
 - Error messages for - validate_length,- validate_array_lengthand- validate_list_lengthare the following:- `is n:- "should be %d element(s)"
- `min n:- "should be at least %d element(s)"
- `max n:- "should be at most %d element(s)"
 - Error messages for - validate_string_lengthare the following:- `is n:- "should be %d character(s)"
- `min n:- "should be at least %d character(s)"
- `max n:- "should be at most %d character(s)"
 
- val validate_length : 'a label ‑> ('a ‑> Base.int) ‑> length_opt Base.list ‑> t ‑> t
- validate_length l f opts tvalidates that the length calculated by applying- fto the value indexed by the label- lin the changeset- trespects the- opts.
- val validate_string_length : Base.string label ‑> length_opt Base.list ‑> t ‑> t
- validate_string_length l opts tvalidates that the length of the string indexed by the label- lin the changeset- trespects the- opts.
- val validate_array_length : 'a Base.array label ‑> length_opt Base.list ‑> t ‑> t
- validate_array_length l opts tvalidates that the length of the array indexed by the label- lin the changeset- trespects the- opts.
- val validate_list_length : 'a Base.list label ‑> length_opt Base.list ‑> t ‑> t
- validate_list_length l opts tvalidates that the length of the list indexed by the label- lin the changeset- trespects the- opts.
- type 'a ord_opt=- [- |- `equal_to of 'a- |- `greater_than of 'a- |- `greater_than_or_equal_to of 'a- |- `less_than of 'a- |- `less_than_or_equal_to of 'a- ]
- val validate : 'a label ‑> (module Base.Comparator.S with type t = 'a) ‑> 'a ord_opt Base.list ‑> t ‑> t
- validate l cmp opts tvalidates that the value indexed by the label- lin the changeset- trespects the- optsusing the- comparefunction provided by the first-class module- cmp.
- val validate_int : Base.int label ‑> Base.int ord_opt Base.list ‑> t ‑> t
- validate_int l opts tvalidates that the integer indexed by label- lin the changeset- trespects the- opts.
- val validate_float : Base.float label ‑> Base.float ord_opt Base.list ‑> t ‑> t
- validate_float l opts tvalidates that float indexed by label- lin the changeset- trespects the- opts.
- val validate_bool : Base.bool label ‑> Base.bool ord_opt Base.list ‑> t ‑> t
- validate_bool l opts tvalidates that the boolean indexed by label- lin the changeset- trespects the- opts.
- val validate_char : Base.char label ‑> Base.char ord_opt Base.list ‑> t ‑> t
- validate_char l opts tvalidates that the char indexed by label- lin the changeset- trespects the- opts.
- val validate_string : Base.string label ‑> Base.string ord_opt Base.list ‑> t ‑> t
- validate_string l opts tvalidates that the string indexed by label- lin the changeset- trespects the- opts.
- val validate_inclusion : 'a label ‑> ('a ‑> 'a ‑> Base.bool) ‑> 'a Base.list ‑> ?message:Base.string ‑> t ‑> t
- validate_inclusion equal l xs ?message tvalidates that the value indexed by label- lin the changeset- tis a an included in- xs. If not, an error- messageindexed by the label- lis added to the changeset- t. Default error message is- "is invalid".
- val validate_exclusion : 'a label ‑> ('a ‑> 'a ‑> Base.bool) ‑> 'a Base.list ‑> ?message:Base.string ‑> t ‑> t
- validate_excluded equal l xs ?message tvalidates that the value indexed by label- lin the changeset- tis not included in- xs. If not, an error- messageindexed by the label- lis added to the changeset- t. Default error message is- "is reserved".
- val validate_acceptance : Base.bool label ‑> ?message:Base.string ‑> t ‑> t
- validate_string l ?message tvalidates that the change indexed by label- lin the changeset- tis- true. If not, an error- messageindexed by the label- lis added to the changeset- t. Default error message is- "must be accepted".
- val validate_format : Base.string label ‑> Str.regexp ‑> ?message:Base.string ‑> t ‑> t
- validate_format l reg ?message tvalidates that the change indexed by label- lin the changeset- tis accepted by the regex- r. If not, an error- messageindexed by the label- lis added to the changeset- t. Default error message is- "has invalid format".