forked from ManasJayanth/flow
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpattern_cover.ml
54 lines (46 loc) · 1.58 KB
/
pattern_cover.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
(**
* Copyright (c) 2013-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*)
open Ast
open Parser_common
open Parser_env
module type COVER = sig
val as_expression : env -> pattern_cover -> Loc.t Expression.t
val as_pattern : ?err:Parse_error.t -> env -> pattern_cover -> Loc.t Pattern.t
val empty_errors : pattern_errors
val rev_append_errors : pattern_errors -> pattern_errors -> pattern_errors
val rev_errors : pattern_errors -> pattern_errors
end
module Cover
(Parse: PARSER)
: COVER = struct
let as_expression env = function
| Cover_expr expr -> expr
| Cover_patt (expr, { if_expr; if_patt = _ }) ->
List.iter (error_at env) if_expr;
expr
let as_pattern ?(err = Parse_error.InvalidLHSInAssignment) env cover =
let expr = match cover with
| Cover_expr expr -> expr
| Cover_patt (expr, { if_expr = _; if_patt }) ->
List.iter (error_at env) if_patt;
expr
in
if not (Parse.is_assignable_lhs expr)
then error_at env (fst expr, err);
(match expr with
| loc, Ast.Expression.Identifier (_, name)
when is_restricted name ->
strict_error_at env (loc, Error.StrictLHSAssignment)
| _ -> ());
Parse.pattern_from_expr env expr
let empty_errors = { if_patt = []; if_expr = [] }
let rev_append_errors a b =
{ if_patt = List.rev_append a.if_patt b.if_patt;
if_expr = List.rev_append a.if_expr b.if_expr; }
let rev_errors a =
{ if_patt = List.rev a.if_patt; if_expr = List.rev a.if_expr }
end