package reason

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Source file reason_recover_parser.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
module M = Reason_multi_parser

module R =
  Merlin_recovery.Make
    (Reason_parser.MenhirInterpreter)
    (struct
      include Reason_parser_recover

      let default_value loc x =
        Default.default_loc := loc;
        default_value x

      let guide _ = false
    end)

type 'a parser =
  | Correct of 'a M.parser
  | Recovering of 'a R.candidates * Reason_lexer.invalid_docstrings

let initial entry_point position = Correct (M.initial entry_point position)

type 'a step =
  | Intermediate of 'a parser
  | Success of 'a * Reason_lexer.invalid_docstrings
  | Error

let step parser token =
  match parser with
  | Correct parser ->
    (match M.step parser token with
    | M.Intermediate parser -> Intermediate (Correct parser)
    | M.Success (x, ds) -> Success (x, ds)
    | M.Error ->
      let _, loc_start, loc_end = token in
      let loc = { Location.loc_start; loc_end; loc_ghost = false } in
      let env, ds = M.recovery_env parser in
      let message = Reason_parser_explain.message env token in
      Reason_errors.raise_error (Reason_errors.Parsing_error message) loc;
      Intermediate (Recovering (R.generate env, ds)))
  | Recovering (candidates, ds) ->
    (match token with
    | Reason_parser.DOCSTRING text, startp, endp ->
      let ds = Reason_lexer.add_invalid_docstring text startp endp ds in
      Intermediate (Recovering (candidates, ds))
    | _ ->
      (match R.attempt candidates token with
      | `Ok (cp, _) -> Intermediate (Correct (M.recover cp ds))
      | `Accept x -> Success (x, ds)
      | `Fail ->
        (match token with
        | Reason_parser.EOF, _, _ ->
          (match candidates.final with
          | None -> Error
          | Some x -> Success (x, ds))
        | _ -> Intermediate parser)))
OCaml

Innovation. Community. Security.