package ppx_repr
PPX deriver for type representations
Install
Dune Dependency
Authors
Maintainers
Sources
repr-fuzz-0.5.0.tbz
sha256=2ed0e1dab950eeb551cbecc3bbc5ddb584b3b3e4b4e039ff3abf7bd6d5b238f9
sha512=bacfef83e5bd2b12a7ccd514ba92525030cdcf85ba1121e9456db7f327c434db599a47667ca9826ab77ed95e0f946347e027bc6c18420c6a8faabf4a491a2a7a
doc/src/ppx_repr.lib/plugins.ml.html
Source file plugins.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
(* * Copyright (c) 2019-2020 Craig Ferguson <me@craigfe.io> * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. *) open Ppxlib module Make (T : sig val namespace : string val default_library : string end) = struct module Attributes = Attributes.Make (T) let with_engine f ~loc ~path:_ = let (module S) = Ast_builder.make loc in f (module Engine.Located (Attributes) (S) : Engine.S) let args () = let open Deriving.Args in Meta_deriving.Args.[ arg "name" (estring __); arg "lib" __ ] let library = lazy (let library = ref (Some T.default_library) in let doc = Format.sprintf "<module-path> Set the module path containing the combinators to \ use (defaults to %s). An empty string is interpreted as the \ current module." T.default_library in Ppxlib.Driver.add_arg "--lib" (Arg.String (function "" -> library := None | s -> library := Some s)) ~doc; library) let register_deriver ?plugins:(supported_plugins = Meta_deriving.Plugin.defaults) () = let library = Lazy.force library in let str_type_decl = let attributes = Attributes.all in Meta_deriving.make_generator ~attributes ~supported_plugins ~args:(args ()) ( with_engine @@ fun (module L) plugins input_ast name lib -> let lib = Option.fold lib ~some:L.parse_lib ~none:!library in L.derive_str ~plugins ~name ~lib input_ast ) in let sig_type_decl = Meta_deriving.make_generator ~supported_plugins ~args:(args ()) ( with_engine @@ fun (module L) plugins input_ast name lib -> let lib = Option.fold lib ~some:L.parse_lib ~none:!library in L.derive_sig ~plugins ~name ~lib input_ast ) in Deriving.add ~str_type_decl ~sig_type_decl T.namespace |> Deriving.ignore let register_extension ?no_reserve_namespace () = let library = Lazy.force library in let extension = Extension.declare (T.namespace ^ ".typ") Extension.Context.expression Ast_pattern.(ptyp __) (with_engine @@ fun (module L) -> L.expand_typ ?lib:!library) in (match no_reserve_namespace with | Some () -> () | None -> Reserved_namespaces.reserve T.namespace); Driver.register_transformation ~extensions:[ extension ] T.namespace end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>