-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOptions.sml
54 lines (52 loc) · 1.29 KB
/
Options.sml
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
structure Options =
struct
val maxTySize = ref 100
val defaultTableSize = ref 100
type opts =
{ test: bool
, printOnly: bool
, recursiveModules: bool
, fileGen: string
, projGen: string
, maxSize: int
, defaultTableSize: int
}
fun updateOpts r =
let
fun from test printOnly recursiveModules fileGen projGen maxSize
defaultTableSize =
{ test = test
, printOnly = printOnly
, recursiveModules = recursiveModules
, fileGen = fileGen
, projGen = projGen
, maxSize = maxSize
, defaultTableSize = defaultTableSize
}
fun to ?
{ test
, printOnly
, recursiveModules
, fileGen
, projGen
, maxSize
, defaultTableSize
} =
?test printOnly recursiveModules fileGen projGen maxSize
defaultTableSize
in
FunctionalRecordUpdate.makeUpdate7 (from, from, to) r
end
val defaultOpts: opts =
{ test = false
, printOnly = true
, recursiveModules = false
, fileGen = ""
, projGen = ""
, maxSize = !maxTySize
, defaultTableSize = !defaultTableSize
}
val opts = let open Fold FunctionalRecordUpdate
in updateOpts defaultOpts set #recursiveModules true $
end
end