forked from ocaml/ocaml
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ocaml_filetypes.ml
117 lines (106 loc) · 4.25 KB
/
ocaml_filetypes.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
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 *)
(* *)
(* Sebastien Hinderer, projet Gallium, INRIA Paris *)
(* *)
(* Copyright 2016 Institut National de Recherche en Informatique et *)
(* en Automatique. *)
(* *)
(* All rights reserved. This file is distributed under the terms of *)
(* the GNU Lesser General Public License version 2.1, with the *)
(* special exception on linking described in the file LICENSE. *)
(* *)
(**************************************************************************)
(* Types of files involved in an OCaml project and related functions *)
type backend_specific = Object | Library | Program
type t =
| Implementation
| Interface
| C
| C_minus_minus
| Lexer
| Grammar
| Binary_interface
| Obj
| Backend_specific of Ocaml_backends.t * backend_specific
| Text (* used by ocamldoc for text only documentation *)
let string_of_backend_specific = function
| Object -> "object"
| Library -> "library"
| Program -> "program"
let string_of_filetype = function
| Implementation -> "implementation"
| Interface -> "interface"
| C -> "C source file"
| C_minus_minus -> "C minus minus source file"
| Lexer -> "lexer"
| Grammar -> "grammar"
| Binary_interface -> "binary interface"
| Obj -> "object"
| Backend_specific (backend, filetype) ->
((Ocaml_backends.string_of_backend backend) ^ " " ^
(string_of_backend_specific filetype))
| Text -> "text"
let extension_of_filetype = function
| Implementation -> "ml"
| Interface -> "mli"
| C -> "c"
| C_minus_minus -> "cmm"
| Lexer -> "mll"
| Grammar -> "mly"
| Binary_interface -> "cmi"
| Obj -> Ocamltest_config.objext
| Backend_specific (backend, filetype) ->
begin match (backend, filetype) with
| (Ocaml_backends.Native, Object) -> "cmx"
| (Ocaml_backends.Native, Library) -> "cmxa"
| (Ocaml_backends.Native, Program) -> "opt"
| (Ocaml_backends.Bytecode, Object) -> "cmo"
| (Ocaml_backends.Bytecode, Library) -> "cma"
| (Ocaml_backends.Bytecode, Program) -> "byte"
end
| Text -> "txt"
let filetype_of_extension = function
| "ml" -> Implementation
| "mli" -> Interface
| "c" -> C
| "cmm" -> C_minus_minus
| "mll" -> Lexer
| "mly" -> Grammar
| "cmi" -> Binary_interface
| "o" -> Obj
| "obj" -> Obj
| "cmx" -> Backend_specific (Ocaml_backends.Native, Object)
| "cmxa" -> Backend_specific (Ocaml_backends.Native, Library)
| "opt" -> Backend_specific (Ocaml_backends.Native, Program)
| "cmo" -> Backend_specific (Ocaml_backends.Bytecode, Object)
| "cma" -> Backend_specific (Ocaml_backends.Bytecode, Library)
| "byte" -> Backend_specific (Ocaml_backends.Bytecode, Program)
| "txt" -> Text
| _ as e -> Printf.eprintf "Unknown file extension %s\n%!" e; exit 2
let split_filename name =
let l = String.length name in
let is_dir_sep name i = name.[i] = Filename.dir_sep.[0] in
let rec search_dot i =
if i < 0 || is_dir_sep name i then (name, "")
else if name.[i] = '.' then
let basename = String.sub name 0 i in
let extension = String.sub name (i+1) (l-i-1) in
(basename, extension)
else search_dot (i - 1) in
search_dot (l - 1)
let filetype filename =
let (basename, extension) = split_filename filename in
(basename, filetype_of_extension extension)
let make_filename (basename, filetype) =
let extension = extension_of_filetype filetype in
basename ^ "." ^ extension
let action_of_filetype = function
| Implementation -> "Compiling implementation"
| Interface -> "Compiling interface"
| C -> "Compiling C source file"
| C_minus_minus -> "Processing C-- file"
| Lexer -> "Generating lexer"
| Grammar -> "Generating parser"
| filetype -> ("nothing to do for " ^ (string_of_filetype filetype))