-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathopt.ml
42 lines (33 loc) · 1.19 KB
/
opt.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
(* Demonstration of the Getopt module *)
open Batteries_uni
open Getopt
let archive = ref false
and update = ref false
and verbose = ref 0
and includ = ref []
and output = ref ""
let bip () = Printf.printf "\007"; flush stdout
let wait () = Unix.sleep 1
let specs =
[
( 'x', "execute", None, Some (fun x -> Printf.printf "execute %s\n" x));
( 'I', "include", None, (append includ));
( 'o', "output", None, (atmost_once output (Error "only one output")));
( 'a', "archive", (set archive true), None);
( 'u', "update", (set update true), None);
( 'v', "verbose", (incr verbose), None);
( 'X', "", Some bip, None);
( 'w', "wait", Some wait, None)
]
let _ =
Array.print ~last:"]\n" String.print stdout Sys.argv;
let restArgsE = Enum.empty () in
let pushArg a = Enum.push restArgsE a in
parse_cmdline specs pushArg;
let restArgs = List.of_enum restArgsE |> List.rev in
Printf.printf "archive = %b\n" !archive;
Printf.printf "update = %b\n" !update;
Printf.printf "verbose = %i\n" !verbose;
Printf.printf "output = %s\n" !output;
List.print ~first:"include: [" ~last:"]\n" String.print stdout !includ;
List.print ~last:"]\n" String.print stdout restArgs