package travesty
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=01661918f73f33b0e6d0cf3851c2d5d6ef76b86332a3e76a4958689ff1a6fd3a
sha512=14e9b0e9ae39055c386c5e996055ce59edf57b9bf9b0055722632520f9c9b0270af571576950be982ed2b86e859361c7344166a38a85fa7d28d45be8f3e18c77
doc/travesty.containers/Travesty_containers/Zipper/Make_marked/On_option/index.html
Module Make_marked.On_option
Source
On_option
is On_monad
specialised to the option monad.
pop_m zipper ~on_empty
behaves like pop
, but executes a custom monadic action on_empty
, instead of returning an error, when the cursor is empty.
val peek_m :
?steps:Base.int ->
'a t ->
on_empty:('a t -> 'a Base.Option.t) ->
'a Base.Option.t
peek_m ?steps zipper ~on_empty
behaves like peek_opt
, but executes a custom monadic action on_empty
, instead of returning None
, when the cursor is empty.
val step_m :
?steps:Base.int ->
'a t ->
on_empty:('a t -> 'a t Base.Option.t) ->
'a t Base.Option.t
step_m ?steps zipper ~on_empty
behaves like step
, but executes a custom monadic action on_empty
, instead of returning an error, when the cursor is empty.
val map_m_head :
'a t ->
f:('a -> 'a Base.option Base.Option.t) ->
on_empty:('a t -> 'a t Base.Option.t) ->
'a t Base.Option.t
map_m_head ?steps zipper ~on_empty
behaves like map_head
, but executes a custom monadic action on_empty
, instead of leaving the zipper unchanged, when the cursor is empty.
val mark_m :
'a t ->
mark:Mark.t ->
on_empty:('a t -> 'a t Base.Option.t) ->
'a t Base.Option.t
mark_m zipper ~mark ~on_empty
behaves like mark
, but executes a custom monadic action on_empty
, instead of returning an error, when the cursor is empty.
val recall_m :
'a t ->
mark:Mark.t ->
on_empty:('a t -> 'a t Base.Option.t) ->
'a t Base.Option.t
recall_m zipper ~mark ~on_empty
behaves like recall
, but executes a custom monadic action on_empty
, instead of returning an error, when the mark can't be found.
val delete_to_mark_m :
'a t ->
mark:Mark.t ->
on_empty:('a t -> 'a t Base.Option.t) ->
'a t Base.Option.t
delete_to_mark_m zipper ~mark ~on_empty
behaves like delete_to_mark
, but executes a custom monadic action on_empty
, instead of returning an error, when the mark can't be found.
val fold_m_until :
'a t ->
f:
('acc ->
'a ->
'a t ->
(Mark.t, 'a, 'acc, 'final) Zipper_types.fold_outcome Base.Option.t) ->
init:'acc ->
finish:('acc -> 'a t -> 'final Base.Option.t) ->
'final Base.Option.t
fold_m_until zipper ~f ~init ~finish
behaves like fold_until
, except that f
and finish
, and therefore the function itself, return results inside a monad context.