]>
git.saurik.com Git - apt.git/blob - apt-pkg/contrib/cmndline.h
   1 // -*- mode: cpp; mode: fold -*- 
   3 // $Id: cmndline.h,v 1.7 1999/10/31 06:32:28 jgg Exp $ 
   4 /* ###################################################################### 
   6    Command Line Class - Sophisticated command line parser 
   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 
  13    Filenames are stripped from the option stream and put into their 
  16    The argument descriptor array can be initialized as: 
  18  CommandLine::Args Args[] =  
  19  {{'q',"quiet","apt::get::quiet",CommandLine::IntLevel}, 
  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  
  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. 
  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 
  42    ##################################################################### */ 
  44 #ifndef PKGLIB_CMNDLINE_H 
  45 #define PKGLIB_CMNDLINE_H 
  49 #include <apt-pkg/configuration.h> 
  61    bool HandleOpt(int &I
,int argc
,const char *argv
[], 
  62                   const char *&Opt
,Args 
*A
,bool PreceedeMatch 
= false); 
  71       InvBoolean 
= (1 << 3), 
  72       ConfigFile 
= (1 << 4) | HasArg
, 
  73       ArbItem 
= (1 << 5) | HasArg
 
  76    const char **FileList
; 
  78    bool Parse(int argc
,const char **argv
); 
  80    unsigned int FileSize() const; 
  81    bool DispatchArg(Dispatch 
*List
,bool NoMatch 
= true); 
  83    CommandLine(Args 
*AList
,Configuration 
*Conf
); 
  87 struct CommandLine::Args
 
  94    inline bool end() {return ShortOpt 
== 0 && LongOpt 
== 0;}; 
  95    inline bool IsBoolean() {return Flags 
== 0 || (Flags 
& (Boolean
|InvBoolean
)) != 0;}; 
  98 struct CommandLine::Dispatch
 
 101    bool (*Handler
)(CommandLine 
&);