File: prog.mli

package info (click to toggle)
ocaml-obuild 0.2.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,456 kB
  • sloc: ml: 14,491; sh: 211; ansic: 34; makefile: 11
file content (117 lines) | stat: -rw-r--r-- 3,575 bytes parent folder | download
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
(** OCaml toolchain and external program paths *)

(** Exception raised when an OCaml program fails *)
exception OCamlProgramError of string

(** Exception raised when tar command fails *)
exception TarError of string

(** Exception raised when pkg-config command fails *)
exception PkgConfigError of string

(** Exception raised when pkg-config doesn't return version *)
exception PkgConfigVersionNotFound

(** Exception raised when pkg-config output is unexpected *)
exception PkgConfigUnexpectedOutput of string

(** Exception raised when a required program is not found *)
exception ProgramNotFound of string

(** OCaml toolchain program getters *)

val get_ocamlopt : unit -> string
(** Get path to ocamlopt (native compiler) *)

val get_ocamlc : unit -> string
(** Get path to ocamlc (bytecode compiler) *)

val get_ocamldep : unit -> string
(** Get path to ocamldep (dependency analyzer) *)

val get_ocamldoc : unit -> string
(** Get path to ocamldoc (documentation generator) *)

val get_ocamlmklib : unit -> string
(** Get path to ocamlmklib (library linker) *)

val get_camlp4 : unit -> string
(** Get path to camlp4 (preprocessor) *)

val get_cc : unit -> string
(** Get path to C compiler (gcc) *)

val get_ranlib : unit -> string
(** Get path to ranlib *)

val get_ar : unit -> string
(** Get path to ar (archiver) *)

val get_ld : unit -> string
(** Get path to ld (linker) *)

val get_pkg_config : unit -> string
(** Get path to pkg-config *)

val get_ocaml : unit -> string
(** Get path to ocaml (toplevel) *)

val get_ocamlmktop : unit -> string
(** Get path to ocamlmktop (custom toplevel builder) *)

(** OCaml configuration *)

val get_ocaml_version : (string, string) Hashtbl.t -> string * string * string
(** [get_ocaml_version cfg] extracts OCaml version as (major, minor, other)

    @param cfg OCaml configuration hashtable
    @return (major, minor, other) version components
    @raise OCamlProgramError if version format is unexpected *)

val get_ocaml_config : unit -> (string, string) Hashtbl.t
(** [get_ocaml_config ()] retrieves OCaml compiler configuration

    Runs "ocamlc -config" and caches the result.

    @return configuration hashtable
    @raise OCamlProgramError if ocamlc fails *)

val get_camlp4_config : unit -> string list
(** [get_camlp4_config ()] retrieves camlp4 library paths

    Runs "camlp4 -where" to get the installation directories.

    @return list of camlp4 library paths
    @raise OCamlProgramError if camlp4 fails *)

(** External tool invocations *)

val run_tar : string -> string -> unit
(** [run_tar output dir] creates a tar.gz archive

    @param output output filename
    @param dir directory to archive
    @raise TarError if tar command fails *)

val run_pkg_config_version : string -> string
(** [run_pkg_config_version name] gets package version from pkg-config

    @param name package name
    @return version string
    @raise PkgConfigError if pkg-config fails
    @raise PkgConfigVersionNotFound if no version returned
    @raise PkgConfigUnexpectedOutput if output format is unexpected *)

val run_pkg_config_includes : string -> string list
(** [run_pkg_config_includes name] gets include flags from pkg-config

    @param name package name
    @return list of include paths (without -I prefix)
    @raise PkgConfigError if pkg-config fails *)

val run_pkg_config_libs : string -> string list
(** [run_pkg_config_libs name] gets library flags from pkg-config

    @param name package name
    @return list of library names (without -l prefix)
    @raise PkgConfigError if pkg-config fails *)