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
|
let Prelude = ../../imports/Prelude.dhall
let Command = ../../Command/type.dhall
let Argument = ../../Argument/type.dhall
let Option = ../../Option/type.dhall
let OptionPrinter = ../../OptionPrinter/type.dhall
let Complete = ./type.dhall
in λ(conditionOptionPrinter : OptionPrinter)
→ λ(c : Complete)
→ let long =
λ(name : Text)
→ Prelude.Optional.map
Text
Argument
( λ(content : Text)
→ Argument.Option { opt = Option.Long name, arg = content }
)
let flag =
λ(name : Text)
→ λ(flag : Bool)
→ if flag
then Some (Argument.Flag (Option.Long name))
else None Argument
let conditionToText =
λ(c : Command Argument)
→ Prelude.Text.concatSep
" "
( ../../Command/toList.dhall
Argument
(../../Argument/toArgList.dhall conditionOptionPrinter)
c
)
: Text
let args =
[ long "command" (Some c.cmd)
, Prelude.Optional.map
(Command Argument)
Argument
( λ(c : Command Argument)
→ Argument.Option
{ opt = Option.Long "condition", arg = conditionToText c }
)
c.condition
, long "short-option" c.short-option
, long "long-option" c.long-option
, long "old-option" c.long-option-old-style
, long "arguments" c.argument
, long "wraps" c.wraps
, flag "keep-order" c.keep-order
, flag "no-files" c.no-files
, flag "require-parameter" c.require-parameter
, long "description" (Some c.description)
]
: List (Optional Argument)
let id = λ(a : Optional Argument) → a
in { cmd =
"complete"
, args =
../../List/filterOptional.dhall
(Optional Argument)
Argument
id
args
: List Argument
}
|