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_polyvar.ml.html
Source file ast_polyvar.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
(* Copyright (C) 2017 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 is_enum_polyvar = let is_enum row_fields = List.for_all ~f:(fun (x : row_field) -> match x.prf_desc with Rtag (_label, true, []) -> true | _ -> false) row_fields in fun (ty : type_declaration) -> match ty.ptype_manifest with | Some { ptyp_desc = Ptyp_variant (row_fields, Closed, None); _ } when is_enum row_fields -> Some row_fields | _ -> None let map_row_fields_into_ints (row_fields : row_field list) ~loc ~allow_no_payload = let _, acc = List.fold_left ~f:(fun (i, acc) rtag -> match rtag.prf_desc with | Rtag ({ txt; _ }, true, []) -> let i = match Ast_attributes.iter_process_mel_int_as rtag.prf_attributes with | Some i -> i | None -> i in (i + 1, (txt, i) :: acc) | Rtag ({ txt; _ }, _, _) when allow_no_payload -> let i = match Ast_attributes.iter_process_mel_int_as rtag.prf_attributes with | Some i -> i | None -> i in (i + 1, (txt, i) :: acc) | _ -> Error.err ~loc Invalid_mel_int_type) ~init:(0, []) row_fields in Melange_ffi.External_arg_spec.Int (List.rev acc) let process_mel_as tag ~txt ~has_mel_as = let name = match Ast_attributes.iter_process_mel_string_as tag.prf_attributes with | Some name -> has_mel_as := true; name | None -> txt in (txt, name) (* It also check in-consistency of cases like {[ [`a | `c of int ] ]} *) let map_row_fields_into_strings (row_fields : row_field list) ~loc ~allow_no_payload = let has_mel_as = ref false in let case, result = List.fold_right ~f:(fun tag (nullary, acc) -> match (nullary, tag.prf_desc) with | (`Nothing | `Null), Rtag ({ txt; _ }, true, []) -> (`Null, process_mel_as tag ~txt ~has_mel_as :: acc) | `NonNull, Rtag ({ txt; _ }, true, []) when allow_no_payload -> (`Null, process_mel_as tag ~txt ~has_mel_as :: acc) | (`Nothing | `NonNull), Rtag ({ txt; _ }, false, [ _ ]) -> (`NonNull, process_mel_as tag ~txt ~has_mel_as :: acc) | _ -> Error.err ~loc Invalid_mel_string_type) row_fields ~init:(`Nothing, []) in match case with | `Nothing -> Error.err ~loc Invalid_mel_string_type | `Null | `NonNull -> ( let has_payload = case = `NonNull in let descr = if !has_mel_as then Some result else None in match (has_payload, descr) with | false, None -> Mel_ast_invariant.warn ~loc Redundant_mel_string; Melange_ffi.External_arg_spec.Nothing | false, Some descr -> Poly_var_string { descr } | true, _ -> Poly_var { descr })
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>