package electrod
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  Formal analysis for the Electrod formal pivot language
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      electrod-0.7.1.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=e5d2278c99128621110cd015dafcbcae9792bbf2c8bb09d7b02c57d50fa28075
    
    
  sha512=e08ecf720d35b6ee72f37d780cc3da22f61e22314ffd093ff3314fb89684b863b5c96c97375d48bcb4ba2838ec8f61a495105c989f292c5dbcd095e14f52bdba
    
    
  doc/src/electrod.libelectrod/Fmtc.ml.html
Source file Fmtc.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 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180(******************************************************************************* * electrod - a model finder for relational first-order linear temporal logic * * Copyright (C) 2016-2020 ONERA * Authors: Julien Brunel (ONERA), David Chemouil (ONERA) * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * SPDX-License-Identifier: MPL-2.0 * License-Filename: LICENSE.md ******************************************************************************) (** Contains pretty-printing facilities. Note: same licence as Fmt. *) (** Licence: ISC *) (** Straight extension of Fmt to avoid having to open Fmt and Fmtc *) include Fmt let nbsp = const string " " let hardline = Format.pp_force_newline let lbrace = const string "{" let rbrace = const string "}" let lparen = const string "(" let rparen = const string ")" let langle = const string "<" let rangle = const string ">" let lbracket = const string "[" let rbracket = const string "]" let squote = const string "'" let dquote = const string "\"" let bquote = const string "`" let semi = const string ";" let colon = const string ":" let comma = const string "," let dot = const string "." let sharp = const string "#" let slash = const string "/" let backslash = const string "\\" let equal = const string "=" let qmark = const string "?" let tilde = const string "~" let at = const string "@" let percent = const string "%" let dollar = const string "$" let caret = const string "^" let ampersand = const string "&" let star = const string "*" let plus = const string "+" let minus = const string "-" let underscore = const string "_" let bang = const string "!" let bar = const string "|" let squotes ppf v = quote ~mark:"'" ppf v let bquotes ppf v = quote ~mark:"`" ppf v let angles pp_v ppf v = pf ppf "@[<1><%a>@]" pp_v v (* all **... operators associate to the RIGHT and are of stronger precedence than @@ but lower than function application *) let ( **@ ) p1 p2 = append p1 p2 let ( **< ) p1 p2 = prefix p1 p2 let ( **> ) p1 p2 = suffix p1 p2 (* append, with a break *hint* in the middle *) let ( **! ) p1 p2 = pair p1 p2 (* append, with a space or a break in the middle *) let ( **- ) p1 p2 = pair ~sep:sp p1 p2 (* creates a box and surrounds it by delimiters bef and aft *) let surround bef aft pp_v out v = bef out (); pp_v out v; aft out () (* like surround, with a non-breakable-space right after bef (resp. right before aft) *) let surround_ bef aft pp_v out v = bef out (); pf out " "; pp_v out v; pf out " "; aft out () let braces_ ppv_v out v = surround_ lbrace rbrace ppv_v out v let brackets_ ppv_v out v = surround_ lbracket rbracket ppv_v out v let parens_ ppv_v out v = surround_ lparen rparen ppv_v out v let angles_ ppv_v out v = surround_ langle rangle ppv_v out v let unless test ppf out v = if test v then pf out "" else ppf out v let repeat n pp = assert (n >= 0); let rec walk n pp = if n = 0 then nop else pp **< walk (n - 1) pp in walk n pp let infix ?(indent = 0) ?(par = true) middle left right out (m, l, r) = if par then pf out "(@[<hov%d>@[%a@]@ %a@ @[%a@]@])" indent left l middle m right r else pf out "@[<hov%d>@[%a@]@ %a@ @[%a@]@]" indent left l middle m right r let prefix ?(indent = 0) ?(par = true) pprefix pbody out (prefix, body) = if par then pf out "(@[<hov%d>%a@[%a@]@])" indent pprefix prefix pbody body else pf out "@[<hov%d>%a@[%a@]@]" indent pprefix prefix pbody body let tuple2 = pair let tuple3 ?sep1:(pp_sep1 = sp) ?sep2:(pp_sep2 = sp) pp1 pp2 pp3 ppf (x1, x2, x3) = pp1 ppf x1; pp_sep1 ppf (); pp2 ppf x2; pp_sep2 ppf (); pp3 ppf x3 let triple = tuple3 let bbox ?(indent = 0) pp ppf = Format.pp_open_box ppf indent; pf ppf "%a@]" pp let bbox2 out v = bbox ~indent:2 out v let box2 out v = box ~indent:2 out v let hbox2 out v = hbox out v let vbox2 out v = vbox ~indent:2 out v let hvbox2 out v = hvbox ~indent:2 out v
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >