package travesty
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=9c7b3803620c54496a35983285242ec8e06a5efb1baa3523384d7184b7e9fab7
    
    
  sha512=991646fe5bb899971d3f8c00432d4df6c45dbd81cbff885b28d30d9c228e5df61f1e8d61aadc164ec35c448093abb34fd7a7d571e1cdf4d3af25579bf400f167
    
    
  doc/travesty.containers/Travesty_containers/Zipper/Int_mark_zipper/On_error/index.html
Module Int_mark_zipper.On_error
On_error is On_monad specialised to the error monad.
val pop_m : 
  'a t ->
  on_empty:('a t -> ('a * 'a t) Base.Or_error.t) ->
  ('a * 'a t) Base.Or_error.tpop_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.Or_error.t) ->
  'a Base.Or_error.tpeek_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.Or_error.t) ->
  'a t Base.Or_error.tstep_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.Or_error.t) ->
  on_empty:('a t -> 'a t Base.Or_error.t) ->
  'a t Base.Or_error.tmap_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:Base.int ->
  on_empty:('a t -> 'a t Base.Or_error.t) ->
  'a t Base.Or_error.tmark_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:Base.int ->
  on_empty:('a t -> 'a t Base.Or_error.t) ->
  'a t Base.Or_error.trecall_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:Base.int ->
  on_empty:('a t -> 'a t Base.Or_error.t) ->
  'a t Base.Or_error.tdelete_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 ->
      (Base.int, 'a, 'acc, 'final) Zipper_types.fold_outcome Base.Or_error.t) ->
  init:'acc ->
  finish:('acc -> 'a t -> 'final Base.Or_error.t) ->
  'final Base.Or_error.tfold_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.