package melange
Toolchain to produce JS from Reason/OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
melange-2.2.0.tbz
sha256=23859d4598ca9e5faac09abd09892d0e6d6afcd727e146ec48978a997a191584
sha512=1ada6f9e81f3fbb388a09752725e0c8b61d2d9b0d1f5c147186870a271766e8353db4115b7b5d3eb2f916ae9a165e2f4480e44b69883c57a3e2420f47e002a19
doc/src/melange_ppx/ast_pat.ml.html
Source file ast_pat.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
(* Copyright (C) 2015-2016 Bloomberg Finance L.P. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * In addition to the permissions granted to you by the LGPL, you may combine * or link a "work that uses the Library" with a publicly distributed version * of this file to produce a combined library or application, then distribute * that combined work under the terms of your choosing, with no requirement * to comply with the obligations normally placed on you by section 4 of the * LGPL version 3 (or the corresponding section of a later version of the LGPL * should you choose to use a later version). * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *) open Ppxlib type t = Parsetree.pattern let is_unit_cont ~yes ~no (p : t) = match p with | { ppat_desc = Ppat_construct ({ txt = Lident "()"; _ }, None); _ } -> yes | _ -> no (** [arity_of_fun pat e] tells the arity of expression [fun pat -> e] *) let arity_of_fun (pat : Parsetree.pattern) (e : Parsetree.expression) = let rec aux (e : Parsetree.expression) = match e.pexp_desc with | Pexp_fun (_, _, _, e) -> 1 + aux e (*FIXME error on optional*) (* | Pexp_fun _ -> Location.raise_errorf ~loc:e.pexp_loc "Label is not allowed in JS object" *) | _ -> 0 in is_unit_cont ~yes:0 ~no:1 pat + aux e let rec labels_of_fun (e : Parsetree.expression) = match e.pexp_desc with | Pexp_fun (l, _, _, e) -> l :: labels_of_fun e | _ -> [] let rec is_single_variable_pattern_conservative (p : t) = match p.ppat_desc with | Parsetree.Ppat_any | Parsetree.Ppat_var _ -> true | Parsetree.Ppat_alias (p, _) | Parsetree.Ppat_constraint (p, _) -> is_single_variable_pattern_conservative p | _ -> false
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>