package melange
Toolchain to produce JS from Reason/OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
melange-5.1.0-53.tbz
sha256=f7aac30f3ba5feff8373e2164cdb5b38a59457cadfec74b564c2b62d035ca4a9
sha512=39a0b7430035b5355bad4f42fb07d719da56e457d78399fc34c38e5eeb6e5e5259f06a1209dc00325818e3dc1dd9a5988f6a25c106d2ee0ee2033ab9074791cd
doc/src/melange_ppx/ast_external.ml.html
Source file ast_external.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 107 108 109 110 111 112 113 114 115 116 117 118 119
(* Copyright (C) 2018 Hongbo Zhang, Authors of ReScript * * 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 pval_prim_default = [ ""; "" ] let single_string_payload_error ~loc = Ast_helper.Exp.constant (Pconst_string ("Melange requires a single string in `external` payloads", loc, None)) let handleExternalInSig (self : Ast_traverse.map) (prim : value_description) (sigi : signature_item) : signature_item = let loc = prim.pval_loc in let pval_type = self#core_type prim.pval_type in let pval_attributes = self#attributes prim.pval_attributes in match prim.pval_prim with | [] -> Location.raise_errorf ~loc "empty primitive string" | _ :: _ :: _ -> [%sigi: [%%ocaml.error [%e single_string_payload_error ~loc]]] | [ v ] -> let { Ast_external_process.pval_type; pval_prim; pval_attributes; dont_inline_cross_module; } = Ast_external_process.handle_attributes_as_string loc pval_type pval_attributes prim.pval_name.txt v in { sigi with psig_desc = Psig_value { prim with pval_type; pval_prim = (if dont_inline_cross_module then [] else pval_prim); pval_attributes = Ast_attributes.unboxable_type_in_prim_decl :: pval_attributes; }; } let handleExternalInStru (self : Ast_traverse.map) (prim : value_description) (str : structure_item) : structure_item = let loc = prim.pval_loc in let pval_type = self#core_type prim.pval_type in let pval_attributes = self#attributes prim.pval_attributes in match prim.pval_prim with | [] -> Location.raise_errorf ~loc "empty primitive string" | _ :: _ :: _ -> [%stri [%%ocaml.error [%e single_string_payload_error ~loc]]] | [ v ] -> let { Ast_external_process.pval_type; pval_prim; pval_attributes; dont_inline_cross_module; } = Ast_external_process.handle_attributes_as_string loc pval_type pval_attributes prim.pval_name.txt v in let external_result = { str with pstr_desc = Pstr_primitive { prim with pval_type; pval_prim; pval_attributes = Ast_attributes.unboxable_type_in_prim_decl :: pval_attributes; }; } in if not dont_inline_cross_module then external_result else let open Ast_helper in Str.include_ ~loc (Incl.mk ~loc (Mod.constraint_ ~loc (Mod.structure ~loc [ external_result ]) (Mty.signature ~loc [ { psig_desc = Psig_value { prim with pval_type; pval_prim = []; pval_attributes; }; psig_loc = loc; }; ])))
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>