forked from ocaml/ocaml
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparse.mli
108 lines (86 loc) · 4.36 KB
/
parse.mli
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
107
108
(**************************************************************************)
(* *)
(* OCaml *)
(* *)
(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)
(* *)
(* Copyright 1996 Institut National de Recherche en Informatique et *)
(* en Automatique. *)
(* *)
(* All rights reserved. This file is distributed under the terms of *)
(* the GNU Lesser General Public License version 2.1, with the *)
(* special exception on linking described in the file LICENSE. *)
(* *)
(**************************************************************************)
(** Entry points in the parser
{b Warning:} this module is unstable and part of
{{!Compiler_libs}compiler-libs}.
*)
val implementation : Lexing.lexbuf -> Parsetree.structure
val interface : Lexing.lexbuf -> Parsetree.signature
val toplevel_phrase : Lexing.lexbuf -> Parsetree.toplevel_phrase
val use_file : Lexing.lexbuf -> Parsetree.toplevel_phrase list
val core_type : Lexing.lexbuf -> Parsetree.core_type
val expression : Lexing.lexbuf -> Parsetree.expression
val pattern : Lexing.lexbuf -> Parsetree.pattern
(** The functions below can be used to parse Longident safely. *)
val longident: Lexing.lexbuf -> Longident.t
(**
The function [longident] is guaranteed to parse all subclasses
of {!Longident.t} used in OCaml: values, constructors, simple or extended
module paths, and types or module types.
However, this function accepts inputs which are not accepted by the
compiler, because they combine functor applications and infix operators.
In valid OCaml syntax, only value-level identifiers may end with infix
operators [Foo.( + )].
Moreover, in value-level identifiers the module path [Foo] must be simple
([M.N] rather than [F(X)]): functor applications may only appear in
type-level identifiers.
As a consequence, a path such as [F(X).( + )] is not a valid OCaml
identifier; but it is accepted by this function.
*)
(** The next functions are specialized to a subclass of {!Longident.t} *)
val val_ident: Lexing.lexbuf -> Longident.t
(**
This function parses a syntactically valid path for a value. For instance,
[x], [M.x], and [(+.)] are valid. Contrarily, [M.A], [F(X).x], and [true]
are rejected.
Longident for OCaml's value cannot contain functor application.
The last component of the {!Longident.t} is not capitalized,
but can be an operator [A.Path.To.(.%.%.(;..)<-)]
*)
val constr_ident: Lexing.lexbuf -> Longident.t
(**
This function parses a syntactically valid path for a variant constructor.
For instance, [A], [M.A] and [M.(::)] are valid, but both [M.a]
and [F(X).A] are rejected.
Longident for OCaml's variant constructors cannot contain functor
application.
The last component of the {!Longident.t} is capitalized,
or it may be one the special constructors: [true],[false],[()],[[]],[(::)].
Among those special constructors, only [(::)] can be prefixed by a module
path ([A.B.C.(::)]).
*)
val simple_module_path: Lexing.lexbuf -> Longident.t
(**
This function parses a syntactically valid path for a module.
For instance, [A], and [M.A] are valid, but both [M.a]
and [F(X).A] are rejected.
Longident for OCaml's module cannot contain functor application.
The last component of the {!Longident.t} is capitalized.
*)
val extended_module_path: Lexing.lexbuf -> Longident.t
(**
This function parse syntactically valid path for an extended module.
For instance, [A.B] and [F(A).B] are valid. Contrarily,
[(.%())] or [[]] are both rejected.
The last component of the {!Longident.t} is capitalized.
*)
val type_ident: Lexing.lexbuf -> Longident.t
(**
This function parse syntactically valid path for a type or a module type.
For instance, [A], [t], [M.t] and [F(X).t] are valid. Contrarily,
[(.%())] or [[]] are both rejected.
In path for type and module types, only operators and special constructors
are rejected.
*)