package caqti
Unified interface to relational database libraries
Install
Dune Dependency
Authors
Maintainers
Sources
caqti-v2.2.4.tbz
sha256=b8ea432820154ec095132c4f7b244b06cd8553e0b2035185b844d9c4f30af8bb
sha512=b7e3ad8e6a9b587db2d517e15cd42df2945148f9223b2fa6f4bc2bcdd2709d53549cca4b65e54511d22466e4c9aa7f0b9c17305a07505519d8bf81d95de629b8
doc/src/caqti.template/request.ml.html
Source file request.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
(* Copyright (C) 2017--2025 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. *) [@@@alert "-caqti_private"] module Log = (val Logs.src_log (Logs.Src.create "caqti")) type prepare_policy = | Direct | Dynamic | Static type ('a, 'b, +'m) t = { id: int option; prepare_policy: prepare_policy; query: Dialect.t -> Query.t; param_type: 'a Row_type.t; row_type: 'b Row_type.t; row_mult: 'm Row_mult.t; } constraint 'm = [< `Zero | `One | `Many] let last_id = ref (-1) let create prepare_policy (param_type, row_type, row_mult) query = let id = (match prepare_policy with | Direct -> None | Static | Dynamic -> incr last_id; Some !last_id) in {id; prepare_policy; query; param_type; row_type; row_mult} let prepare_policy request = request.prepare_policy let param_type request = request.param_type let row_type request = request.row_type let row_mult request = request.row_mult let query_id request = request.id let query request = request.query let empty_subst _ = raise Not_found let default_dialect = Dialect.create_unknown ~purpose:`Printing () let make_pp ?(dialect = default_dialect) ?(subst = empty_subst) () ppf req = let query = Query.expand subst (req.query dialect) in Format.fprintf ppf "(%a -->%s %a) {|%a|}" Row_type.pp req.param_type (match Row_mult.expose req.row_mult with | `Zero -> "." | `One -> "" | `Zero_or_one -> "?" | `Zero_or_more -> "*") Row_type.pp req.row_type Query.pp query let pp ppf = make_pp () ppf let pp_with_param_enabled = (match Sys.getenv "CAQTI_DEBUG_PARAM" with | "true" -> true | "false" -> false | s -> Log.err (fun f -> f "Invalid value %s for CAQTI_DEBUG_PARAM, assuming false." s); false | exception Not_found -> false) let make_pp_with_param ?dialect ?subst () ppf (req, param) = let pp = make_pp ?subst ?dialect () in pp ppf req; if pp_with_param_enabled then Format.fprintf ppf " %a" Row_type.pp_value (req.param_type, param) type liveness_witness = int option let liveness_witness request = assert (request.id <> None); request.id
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>