]> git.saurik.com Git - apt.git/blob - apt-pkg/contrib/cmndline.h
Merge remote-tracking branch 'mvo/feature/more-fancy-progress' into debian/sid
[apt.git] / apt-pkg / contrib / cmndline.h
1 // -*- mode: cpp; mode: fold -*-
2 // Description /*{{{*/
3 // $Id: cmndline.h,v 1.7 1999/10/31 06:32:28 jgg Exp $
4 /* ######################################################################
5
6 Command Line Class - Sophisticated command line parser
7
8 This class provides a unified command line parser/option handliner/
9 configuration mechanism. It allows the caller to specify the option
10 set and map the option set into the configuration class or other
11 special functioning.
12
13 Filenames are stripped from the option stream and put into their
14 own array.
15
16 The argument descriptor array can be initialized as:
17
18 CommandLine::Args Args[] =
19 {{'q',"quiet","apt::get::quiet",CommandLine::IntLevel},
20 {0,0,0,0}};
21
22 The flags mean,
23 HasArg - Means the argument has a value
24 IntLevel - Means the argument is an integer level indication, the
25 following -qqqq (+3) -q5 (=5) -q=5 (=5) are valid
26 Boolean - Means it is true/false or yes/no.
27 -d (true) --no-d (false) --yes-d (true)
28 --long (true) --no-long (false) --yes-long (true)
29 -d=yes (true) -d=no (false) Words like enable, disable,
30 true false, yes no and on off are recognized in logical
31 places.
32 InvBoolean - Same as boolean but the case with no specified sense
33 (first case) is set to false.
34 ConfigFile - Means this flag should be interprited as the name of
35 a config file to read in at this point in option processing.
36 Implies HasArg.
37 ArbItem - Means the item is an arbitrary configuration string of
38 the form item=value, where item is passed directly
39 to the configuration class.
40 The default, if the flags are 0 is to use Boolean
41
42 ##################################################################### */
43 /*}}}*/
44 #ifndef PKGLIB_CMNDLINE_H
45 #define PKGLIB_CMNDLINE_H
46
47 #include <apt-pkg/macros.h>
48
49 #ifndef APT_8_CLEANER_HEADERS
50 #include <apt-pkg/configuration.h>
51 #endif
52
53 class Configuration;
54
55 class CommandLine
56 {
57 public:
58 struct Args;
59 struct Dispatch;
60
61 protected:
62
63 Args *ArgList;
64 Configuration *Conf;
65 bool HandleOpt(int &I,int argc,const char *argv[],
66 const char *&Opt,Args *A,bool PreceedeMatch = false);
67 void static SaveInConfig(unsigned int const &argc, char const * const * const argv);
68
69 public:
70
71 enum AFlags
72 {
73 HasArg = (1 << 0),
74 IntLevel = (1 << 1),
75 Boolean = (1 << 2),
76 InvBoolean = (1 << 3),
77 ConfigFile = (1 << 4) | HasArg,
78 ArbItem = (1 << 5) | HasArg
79 };
80
81 const char **FileList;
82
83 bool Parse(int argc,const char **argv);
84 void ShowHelp();
85 unsigned int FileSize() const APT_PURE;
86 bool DispatchArg(Dispatch *List,bool NoMatch = true);
87
88 static char const * GetCommand(Dispatch const * const Map,
89 unsigned int const argc, char const * const * const argv) APT_PURE;
90
91 static CommandLine::Args MakeArgs(char ShortOpt, char const *LongOpt,
92 char const *ConfName, unsigned long Flags) APT_CONST;
93
94 CommandLine(Args *AList,Configuration *Conf);
95 ~CommandLine();
96 };
97
98 struct CommandLine::Args
99 {
100 char ShortOpt;
101 const char *LongOpt;
102 const char *ConfName;
103 unsigned long Flags;
104
105 inline bool end() {return ShortOpt == 0 && LongOpt == 0;};
106 inline bool IsBoolean() {return Flags == 0 || (Flags & (Boolean|InvBoolean)) != 0;};
107 };
108
109 struct CommandLine::Dispatch
110 {
111 const char *Match;
112 bool (*Handler)(CommandLine &);
113 };
114
115 #endif