Source file reason.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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
open Types
module O = Codefmt
open O.Infix

module Reason = Generator.Make (struct
  module Obj = struct
    let close_tag_closed = "}"

    let close_tag_extendable = "}"

    let field_separator = ", "

    let open_tag_closed = "{. "

    let open_tag_extendable = "{.. "
  end

  module Type = struct
    let annotation_separator = ": "

    let handle_constructor_params name args = name ++ args

    let handle_substitution_params name args = name ++ args

    let handle_format_params p = "(" ^ p ^ ")"

    let type_def_semicolon = true

    let private_keyword = "pri"

    let parenthesize_constructor = true

    module Variant = struct
      let parenthesize_params = true
    end

    module Tuple = struct
      let element_separator = O.txt ", "

      let always_parenthesize = true
    end

    module Record = struct
      let field_separator = ","
    end

    let var_prefix = "'"

    let any = "_"

    let arrow = O.span ~attr:"arrow" (O.txt "=" ++ O.entity "gt")

    module Exception = struct
      let semicolon = true
    end

    module GADT = struct
      let arrow = O.txt ":"
    end

    module External = struct
      let semicolon = true

      let handle_primitives prims =
        List.fold_left
          (fun acc p ->
            let str =
              match acc with [] -> "\"" ^ p ^ "\"" | _ -> " \"" ^ p ^ "\""
            in
            inline (Text str) :: acc)
          [] prims
    end
  end

  module Mod = struct
    let open_tag = O.txt "{"

    let close_tag = O.txt "}"

    let close_tag_semicolon = true

    let include_semicolon = true

    let functor_keyword = false

    let functor_contraction = false
  end

  module Class = struct
    let open_tag = O.txt "{"

    let close_tag = O.txt "}"
  end

  module Value = struct
    let variable_keyword = "let"

    let semicolon = true
  end

  module Comment = struct
    let markers = ("/*", "*/")
  end
end)

include Reason