Provided by: ocaml-man_4.14.1-1ubuntu1_all bug

NAME

       Local_store  -  This  module provides some facilities for creating references (and hash tables) which can
       easily be snapshoted and restored to an arbitrary version.

Module

       Module   Local_store

Documentation

       Module Local_store
        : sig end

       This module provides some facilities for creating references  (and  hash  tables)  which  can  easily  be
       snapshoted and restored to an arbitrary version.

       It  is  used  throughout  the  frontend (read: typechecker), to register all (well, hopefully) the global
       state. Thus making it easy for tools like Merlin to go back and forth typechecking different files.

   Creators
       val s_ref : 'a -> 'a ref

       Similar to ref , except the allocated reference is registered into the store.

       val s_table : ('a -> 'b) -> 'a -> 'b ref

       Used to register hash tables. Those also need to be placed into refs to be easily swapped  out,  but  one
       can't just "snapshot" the initial value to create fresh instances, so instead an initializer is required.

       Use it like this:
             let my_table = s_table Hashtbl.create 42

   State management
       Note: all the following functions are currently unused inside the compiler codebase. Merlin is their only
       user at the moment.

       type store

       val fresh : unit -> store

       Returns a fresh instance of the store.

       The  first  time  this function is called, it snapshots the value of all the registered references, later
       calls to fresh will return instances initialized to those values.

       val with_store : store -> (unit -> 'a) -> 'a

       with_store s f resets all the registered references to the value they have in s for the run of f .  If  f
       updates any of the registered refs, s is updated to remember those changes.

       val reset : unit -> unit

       Resets  all  the  references  to  the  initial snapshot (i.e. to the same values that new instances start
       with).

       val is_bound : unit -> bool

       Returns true when a store is active (i.e. when called from the callback passed to  Local_store.with_store
       ), false otherwise.

OCamldoc                                           2023-10-26                                    Local_store(3o)