Merlin_kernel.MtyperMtyper essentially produces a typedtree, but to make sense of it the OCaml typechecker need to be in a specific state.
The result type wraps a snapshot of this state with the typedtree to ensure correct accesses.
type typedtree = [ | `Interface of Ocaml_typing.Typedtree.signature| `Implementation of Ocaml_typing.Typedtree.structure ]type index =
Ocaml_parsing.Longident.t Ocaml_parsing.Location.loc list
Ocaml_typing.Shape.Uid.Map.tval set_index_items :
(index ->
Mconfig.t ->
[ `Impl of Ocaml_typing.Typedtree.structure_item list
| `Intf of Ocaml_typing.Typedtree.signature_item list ] ->
index) ->
unitval run : Mconfig.t -> Mreader.parsetree -> resultval get_env : ?pos:Msource.position -> result -> Ocaml_typing.Env.tval get_stamp : result -> intval get_errors : result -> exn listval initial_env : result -> Ocaml_typing.Env.tval get_cache_stat : result -> typer_cache_statsval node_at :
?skip_recovered:bool ->
?let_pun_behavior:Mbrowse.Let_pun_behavior.t ->
result ->
Lexing.position ->
Mbrowse.tHeuristic to find suitable environment to complete / type at given position. * 1. Try to find environment near given cursor. * 2. Check if there is an invalid construct between found env and cursor : * Case a. * > let x = valid_expr || * The env found is the right most env from valid_expr, it's a correct * answer. * Case b. * > let x = valid_expr * > let y = invalid_construction|| * In this case, the env found is the same as in case a, however it is * preferable to use env from enclosing module rather than an env from * inside x definition.