package ctypes

  1. Overview
  2. Docs
Combinators for binding to C libraries without writing any C

Install

Dune Dependency

Authors

Maintainers

Sources

0.22.0.tar.gz
sha256=aa797c5d6bcaee8883aece2d1d9a524fc1f63c78c1538b0fe69969c0e989419f
md5=8a301a3e3b79156448a6659859ad506c

doc/src/ctypes.top/install_ctypes_printers.ml.html

Source file install_ctypes_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
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
(* Adapted from Anil Madhavapeddy's ocaml-uri package. *)

let printers = [ "Ctypes_printers.format_typ";
                 "Ctypes_printers.format_fn"; 
                 "Ctypes_printers.format_sint";
                 "Ctypes_printers.format_long";
                 "Ctypes_printers.format_llong";
                 "Ctypes_printers.format_uchar";
                 "Ctypes_printers.format_uint8";
                 "Ctypes_printers.format_uint16";
                 "Ctypes_printers.format_uint32";
                 "Ctypes_printers.format_uint64";
                 "Ctypes_printers.format_size_t";
                 "Ctypes_printers.format_ushort";
                 "Ctypes_printers.format_uint";
                 "Ctypes_printers.format_ulong";
                 "Ctypes_printers.format_ullong";
                 "Ctypes_printers.format_pointer";
                 "Ctypes_printers.format_struct";
                 "Ctypes_printers.format_union";
                 "Ctypes_printers.format_array";
                 "Ctypes_printers.format_ocaml";
                 "Ctypes_printers.format_clock_t";
                 "Ctypes_printers.format_dev_t";
                 "Ctypes_printers.format_ino_t";
                 "Ctypes_printers.format_mode_t";
                 "Ctypes_printers.format_nlink_t";
                 "Ctypes_printers.format_off_t";
                 "Ctypes_printers.format_pid_t";
                 "Ctypes_printers.format_size_t";
                 "Ctypes_printers.format_ssize_t";
                 "Ctypes_printers.format_time_t";
                 "Ctypes_printers.format_useconds_t";
                 "Ctypes_printers.format_ldouble";
                 "Ctypes_printers.format_complexld";]

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 ctypes-printers@."
OCaml

Innovation. Community. Security.