package lambdapi
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  Proof assistant for the λΠ-calculus modulo rewriting
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      lambdapi-2.2.0.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=920de48ec6c2c3223b6b93879bb65d07ea24aa27f7f7176b3de16e5e467b9939
    
    
  sha512=135f132730825adeb084669222e68bc999de97b12378fae6abcd9f91ae13093eab29fa49c854adb28d064d52c9890c0f5c8ff9d47a9916f66fe5e0fba3479759
    
    
  doc/src/lambdapi.lplib/color.ml.html
Source file color.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(** [color] tells whether colors can be used in the output. *) let color : bool Stdlib.ref = Stdlib.ref true (** Format transformers (colors). *) type color = Red | Gre | Yel | Blu | Mag | Cya type Format.stag += Color of color let color_code = function | Red -> "31" | Gre -> "32" | Yel -> "33" | Blu -> "34" | Mag -> "35" | Cya -> "36" let string_of_color = function | Red -> "red" | Gre -> "gre" | Yel -> "yel" | Blu -> "blu" | Mag -> "mag" | Cya -> "cya" let color_of_string = function | "red" -> Red | "gre" -> Gre | "yel" -> Yel | "blu" -> Blu | "mag" -> Mag | "cya" -> Cya | s -> invalid_arg @@ "color_of_string: unknown color: [" ^ s ^ "]" let rec mark_open_stag old = function | Color c -> "\027[" ^ color_code c ^ "m" | Format.String_tag s -> begin try mark_open_stag old (Color (color_of_string s)) with Stdlib.Invalid_argument _ -> old @@ Format.String_tag s end | stag -> old stag let rec mark_close_stag old = function | Color _ -> "\027[0m" | Format.String_tag s -> begin try mark_close_stag old (Color (color_of_string s)) with Stdlib.Invalid_argument _ -> old @@ Format.String_tag s end | stag -> old stag let update_with_color fmt = if Stdlib.(!color) <> Format.pp_get_mark_tags fmt () then begin Format.pp_set_tags fmt Stdlib.(!color); let old_stag_functions = Format.pp_get_formatter_stag_functions fmt () in let mark_open_stag = mark_open_stag old_stag_functions.mark_open_stag and mark_close_stag = mark_close_stag old_stag_functions.mark_close_stag in Format.pp_set_formatter_stag_functions fmt { old_stag_functions with mark_open_stag; mark_close_stag } end let colorize k format = Scanf.format_from_string ("@{<" ^ string_of_color k ^ ">" ^ string_of_format format ^ "@}") format let pp p_col printer fmt = update_with_color fmt; let a : _ format = "%a" in Format.fprintf fmt (p_col a) printer let red fmt = colorize Red fmt let gre fmt = colorize Gre fmt let yel fmt = colorize Yel fmt let blu fmt = colorize Blu fmt let mag fmt = colorize Mag fmt let cya fmt = colorize Cya fmt (** [g_or_r cond fmt] colors the format [fmt] in green if [cond] is [true] and in red otherwise. *) let g_or_r cond = if cond then gre else red
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >