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
open ExtLib
open Dose_common
let vpkg_option ?default ?(metavar = " <vpkg>") () =
let parse_vpkg s =
let _loc = Format822.dummy_loc in
Dose_pef.Packages.parse_vpkg ("cmdline <vpkg>", (_loc, s))
in
OptParse.Opt.value_option metavar default parse_vpkg (fun _ s ->
Printf.sprintf "invalid vpackage '%s'" s)
let vpkglist_option ?default ?(metavar = " <vpkglst>") () =
let parse_vpkglist s =
let _loc = Format822.dummy_loc in
Dose_pef.Packages.parse_vpkglist ("cmdline <vpkglst>", (_loc, s))
in
OptParse.Opt.value_option metavar default parse_vpkglist (fun _ s ->
Printf.sprintf "invalid vpackage list '%s'" s)
let pkglist_option ?default ?(metavar = " <pkglst>") () =
let parse_vpkglist s =
let _loc = Format822.dummy_loc in
List.map
(function
| ((n, a), Some ("=", v)) -> (n, a, v)
| ((_, _), None) ->
raise (Format822.ParseError ([], s, "you must specify a version"))
| _ -> raise (Format822.ParseError ([], s, "")))
(Dose_pef.Packages.parse_vpkglist ("cmdline <pkglst>", (_loc, s)))
in
OptParse.Opt.value_option metavar default parse_vpkglist (fun _ s ->
Printf.sprintf "invalid package list '%s'" s)
let pkglist tables universe vpkglist =
let to_cudf (p, v) =
(p, Dose_debian.Debcudf.get_cudf_version tables (p, v))
in
List.flatten
(List.map
(fun ((n, a), c) ->
let (name, filter) = Dose_pef.Pefcudf.pefvpkg to_cudf ((n, a), c) in
Cudf.lookup_packages ~filter universe name)
vpkglist)