Incremental.Make_with_configSourcemodule C : Incremental_configinclude S_gen
with type 'a t = ('a, state_witness) incremental
with type Before_or_after.t = Before_or_after.t
with type Clock.t = state_witness Clock.t
with type 'a Cutoff.t = 'a Cutoff.t
with type 'a Expert.Dependency.t = ('a, state_witness) Expert.Dependency.t
with type 'a Expert.Node.t = ('a, state_witness) Expert.Node.t
with type Expert.Step_result.t = Expert.Step_result.t
with type 'a Observer.t = ('a, state_witness) Observer.t
with type 'a Observer.Update.t = 'a Observer.Update.t
with type Packed.t = Packed.t
with type Scope.t = state_witness Scope.t
with type State.t = state_witness State.t
with type State.Stats.t = State.Stats.t
with type ('a, 'b) Unordered_array_fold_update.t =
('a, 'b) Unordered_array_fold_update.t
with type 'a Update.t = 'a Update.t
with type 'a Var.t = ('a, state_witness) Var.ttype 'a incremental := 'a tinclude Core.Invariant.S1 with type 'a t := 'a tval unordered_array_fold :
?full_compute_every_n_changes:int ->
'a t array ->
init:'b ->
f:('b -> 'a -> 'b) ->
update:('a, 'b) Unordered_array_fold_update.t ->
'b tval memoize_fun :
?initial_size:int ->
'a Base.Hashtbl.Key.t ->
('a -> 'b) ->
('a -> 'b) Core.Staged.tval memoize_fun_by_key :
?initial_size:int ->
'key Base.Hashtbl.Key.t ->
('a -> 'key) ->
('a -> 'b) ->
('a -> 'b) Core.Staged.tval weak_memoize_fun :
?initial_size:int ->
'a Base.Hashtbl.Key.t ->
('a -> 'b Core.Heap_block.t) ->
('a -> 'b Core.Heap_block.t) Core.Staged.tval weak_memoize_fun_by_key :
?initial_size:int ->
'key Base.Hashtbl.Key.t ->
('a -> 'key) ->
('a -> 'b Core.Heap_block.t) ->
('a -> 'b Core.Heap_block.t) Core.Staged.tval append_user_info_graphviz :
_ t ->
label:string list ->
attrs:string Core.String.Map.t ->
unitnode_value t returns whatever value t happens to have in it, regardless of whether t is valid, necessary, or stale. One should use observe for a more sensible semantics, reserving node_value for debugging.