package melange
Toolchain to produce JS from Reason/OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
melange-5.0.1-51.tbz
sha256=7753da6c74f2dc6ac610ec71c96ba7c7230dfec1af3fd60c587767643112fc6e
sha512=5be34a60d44ae5423bd3552d967db2cab462aeb17a2a28050a87b2a714e74b944f532763b804e5472b2cef37eeabf99885a66eddfb030e6e21826d2214880768
doc/src/melange_ppx/ast_mel_open.ml.html
Source file ast_mel_open.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
(* 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 Import let isCamlExceptionOrOpenVariant : Longident.t = Ldot (Ldot (Lident "Js", "Exn"), "isCamlExceptionOrOpenVariant") let obj_magic : Longident.t = Ldot (Lident "Obj", "magic") let rec checkCases (cases : case list) = List.iter ~f:check_case cases and check_case case = check_pat case.pc_lhs and check_pat pat = match pat.ppat_desc with | Ppat_construct _ -> () | Ppat_or (l, r) -> check_pat l; check_pat r | _ -> Location.raise_errorf ~loc:pat.ppat_loc "Unsupported pattern. `[@mel.open]' requires patterns to be \ (exception) constructors" let convert_mel_error_function loc (self : Ast_traverse.map) attrs (cases : case list) = let open Ast_helper in let txt = "match" in let txt_expr = Exp.ident ~loc { txt = Lident txt; loc } in let none = Exp.construct ~loc { txt = Ast_literal.predef_none; loc } None in let () = checkCases cases in let cases = self#cases cases in Exp.fun_ ~attrs ~loc Nolabel None (Pat.var ~loc { txt; loc }) (Exp.ifthenelse ~loc [%expr [%e Exp.ident ~loc { txt = isCamlExceptionOrOpenVariant; loc }] [%e txt_expr]] (Exp.match_ ~loc (Exp.constraint_ ~loc [%expr [%e Exp.ident ~loc { txt = obj_magic; loc }] [%e txt_expr]] [%type: exn]) (List.map ~f:(fun x -> let pc_rhs = x.pc_rhs in let loc = pc_rhs.pexp_loc in { x with pc_rhs = Exp.construct ~loc { txt = Ast_literal.predef_some; loc } (Some pc_rhs); }) cases @ [ Exp.case (Pat.any ~loc ()) none ])) (Some none))
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>