package caqti
Unified interface to relational database libraries
Install
Dune Dependency
Authors
Maintainers
Sources
caqti-v2.0.1.tbz
sha256=7eb57225c521fe25395653d960b1c381bb2b2ccae47bc2a827bb16611988da8b
sha512=eeafaf495b08fb8620ddee1711b8f9fa2ca0c79fb450a905c8d071806b7046d665e1e2ac0e7d3c7ca1258455decbf184e689e9ecb2453ec9d952b864f9dd14f4
doc/src/caqti.platform/driver_loader.ml.html
Source file driver_loader.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
(* Copyright (C) 2022--2023 Petter A. Urkedal <paurkedal@gmail.com> * * This library 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, with the LGPL-3.0 Linking Exception. * * This library 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 * and the LGPL-3.0 Linking Exception along with this library. If not, see * <http://www.gnu.org/licenses/> and <https://spdx.org>, respectively. *) module type DRIVER = sig type +'a fiber type (+'a, +'err) stream type switch type stdenv module type CONNECTION = Caqti_connection_sig.S with type 'a fiber := 'a fiber and type ('a, 'err) stream := ('a, 'err) stream val driver_info : Caqti_driver_info.t val connect : sw: switch -> stdenv: stdenv -> ?env: (Caqti_driver_info.t -> string -> Caqti_query.t) -> tweaks_version: int * int -> Uri.t -> ((module CONNECTION), [> Caqti_error.connect]) result fiber end module type DRIVER_FUNCTOR = functor (System : System_sig.S) -> DRIVER with type 'a fiber := 'a System.Fiber.t and type ('a, 'err) stream := ('a, 'err) System.Stream.t and type switch := System.Switch.t and type stdenv := System.stdenv let drivers = Hashtbl.create 5 let register scheme p = Hashtbl.add drivers scheme p module type S = sig type +'a fiber type (+'a, +'e) stream type switch type stdenv module type CONNECTION = Caqti_connection_sig.S with type 'a fiber := 'a fiber and type ('a, 'e) stream := ('a, 'e) stream module type DRIVER = DRIVER with type 'a fiber := 'a fiber and type ('a, 'e) stream := ('a, 'e) stream and type switch := switch and type stdenv := stdenv val load_driver : uri: Uri.t -> string -> ((module DRIVER), [> Caqti_error.load]) result end module Make (System : System_sig.S) = struct module type DRIVER = DRIVER with type 'a fiber := 'a System.Fiber.t and type ('a, 'e) stream := ('a, 'e) System.Stream.t and type switch := System.Switch.t and type stdenv := System.stdenv module type CONNECTION = Caqti_connection_sig.S with type 'a fiber := 'a System.Fiber.t and type ('a, 'e) stream := ('a, 'e) System.Stream.t let load_driver ~uri scheme = (match Hashtbl.find_opt drivers scheme with | None -> let msg = "Driver not found; UNIX drivers not considered." in Error (Caqti_error.load_failed ~uri (Caqti_error.Msg msg)) | Some make_driver -> let module Make_driver = (val make_driver : DRIVER_FUNCTOR) in let module Driver = Make_driver (System) in Ok (module Driver : DRIVER)) end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>