package lacaml

  1. Overview
  2. Docs

Source file install_printers.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
let printers =
  [
    "Lacaml.Io.Toplevel.pp_rfvec";
    "Lacaml.Io.Toplevel.pp_rcvec";
    "Lacaml.Io.Toplevel.pp_rivec";
    "Lacaml.Io.Toplevel.pp_fmat";
    "Lacaml.Io.Toplevel.pp_cmat";
    "Lacaml.Io.Toplevel.pp_imat";
  ]

let eval_string
      ?(print_outcome = false) ?(err_formatter = Format.err_formatter) str =
  let lexbuf = Lexing.from_string str in
  let phrase = !Toploop.parse_toplevel_phrase lexbuf in
  Toploop.execute_phrase print_outcome err_formatter phrase

let rec install_printers = function
  | [] -> true
  | printer :: printers ->
      let cmd = Printf.sprintf "#install_printer %s;;" printer in
      eval_string cmd && install_printers printers

let () =
  if not (install_printers printers) then
    Format.eprintf "Problem installing LACAML-printers@."
OCaml

Innovation. Community. Security.