]> git.saurik.com Git - apt.git/blob - apt-pkg/contrib/configuration.h
Reverted unnecessary string changes
[apt.git] / apt-pkg / contrib / configuration.h
1 // -*- mode: cpp; mode: fold -*-
2 // Description /*{{{*/
3 // $Id: configuration.h,v 1.14 2001/05/07 05:06:52 jgg Exp $
4 /* ######################################################################
5
6 Configuration Class
7
8 This class provides a configuration file and command line parser
9 for a tree-oriented configuration environment. All runtime configuration
10 is stored in here.
11
12 Each configuration name is given as a fully scoped string such as
13 Foo::Bar
14 And has associated with it a text string. The Configuration class only
15 provides storage and lookup for this tree, other classes provide
16 configuration file formats (and parsers/emitters if needed).
17
18 Most things can get by quite happily with,
19 cout << _config->Find("Foo::Bar") << endl;
20
21 A special extension, support for ordered lists is provided by using the
22 special syntax, "block::list::" the trailing :: designates the
23 item as a list. To access the list you must use the tree function on
24 "block::list".
25
26 ##################################################################### */
27 /*}}}*/
28 #ifndef PKGLIB_CONFIGURATION_H
29 #define PKGLIB_CONFIGURATION_H
30
31 #ifdef __GNUG__
32 #pragma interface "apt-pkg/configuration.h"
33 #endif
34
35 #include <string>
36
37 using std::string;
38
39 class Configuration
40 {
41 public:
42
43 struct Item
44 {
45 string Value;
46 string Tag;
47 Item *Parent;
48 Item *Child;
49 Item *Next;
50
51 string FullTag(const Item *Stop = 0) const;
52
53 Item() : Parent(0), Child(0), Next(0) {};
54 };
55
56 private:
57
58 Item *Root;
59 bool ToFree;
60
61 Item *Lookup(Item *Head,const char *S,unsigned long Len,bool Create);
62 Item *Lookup(const char *Name,bool Create);
63 inline const Item *Lookup(const char *Name) const
64 {
65 return ((Configuration *)this)->Lookup(Name,false);
66 }
67
68 public:
69
70 string Find(const char *Name,const char *Default = 0) const;
71 string Find(string Name,const char *Default = 0) const {return Find(Name.c_str(),Default);};
72 string FindFile(const char *Name,const char *Default = 0) const;
73 string FindDir(const char *Name,const char *Default = 0) const;
74 int FindI(const char *Name,int Default = 0) const;
75 int FindI(string Name,int Default = 0) const {return FindI(Name.c_str(),Default);};
76 bool FindB(const char *Name,bool Default = false) const;
77 bool FindB(string Name,bool Default = false) const {return FindB(Name.c_str(),Default);};
78 string FindAny(const char *Name,const char *Default = 0) const;
79
80 inline void Set(string Name,string Value) {Set(Name.c_str(),Value);};
81 void CndSet(const char *Name,string Value);
82 void Set(const char *Name,string Value);
83 void Set(const char *Name,int Value);
84
85 inline bool Exists(string Name) const {return Exists(Name.c_str());};
86 bool Exists(const char *Name) const;
87 bool ExistsAny(const char *Name) const;
88
89 void Clear(string Name);
90
91 inline const Item *Tree(const char *Name) const {return Lookup(Name);};
92
93 void Dump();
94
95 Configuration(const Item *Root);
96 Configuration();
97 ~Configuration();
98 };
99
100 extern Configuration *_config;
101
102 bool ReadConfigFile(Configuration &Conf,string FName,bool AsSectional = false,
103 unsigned Depth = 0);
104
105 bool ReadConfigDir(Configuration &Conf,string Dir,bool AsSectional = false,
106 unsigned Depth = 0);
107
108 #endif