package slap

  1. Overview
  2. Docs

Source file install_top.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
let printers =
  [
    "Slap.Io.Toplevel.pp_rfvec";
    "Slap.Io.Toplevel.pp_rcvec";
    "Slap.Io.Toplevel.pp_rivec";
    "Slap.Io.Toplevel.pp_fmat";
    "Slap.Io.Toplevel.pp_cmat";
    "Slap.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 install_printers printers =
  List.for_all
    (fun printer ->
     let cmd = Printf.sprintf "#install_printer %s;;" printer in
     eval_string cmd)
    printers

let install_ssc () =
  eval_string "let ssc = Slap.Io.Toplevel.ssc;;"
  && eval_string "let lsc = Slap.Io.Toplevel.lsc;;"

let () =
  if not (install_ssc () && install_printers printers) then
    Format.eprintf "Problem installing SLAP-top@."
OCaml

Innovation. Community. Security.