]> git.decadent.org.uk Git - dak.git/blob - tools/dsync-0.0/libdsync/contrib/configuration.h
cron.daily: nag backports team about pending uploads
[dak.git] / tools / dsync-0.0 / libdsync / contrib / configuration.h
1 // -*- mode: cpp; mode: fold -*-
2 // Description                                                          /*{{{*/
3 // $Id: configuration.h,v 1.4 1999/10/24 06:53:12 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 "dsync/configuration.h"
33 #endif 
34
35 #include <string>
36 using namespace std;
37
38 class Configuration
39 {
40 public:
41    struct Item
42    {
43       string Value;
44       string Tag;
45       Item *Parent;
46       Item *Child;
47       Item *Next;
48       
49       string FullTag() const;
50       
51       Item() : Parent(0), Child(0), Next(0) {};
52    };
53 private:
54    Item *Root;
55    
56    Item *Lookup(Item *Head,const char *S,unsigned long Len,bool Create);
57    Item *Lookup(const char *Name,bool Create);
58       
59    public:
60
61    string Find(const char *Name,const char *Default = 0);
62    string Find(string Name,const char *Default = 0) {return Find(Name.c_str(),Default);};
63    string FindFile(const char *Name,const char *Default = 0);
64    string FindDir(const char *Name,const char *Default = 0);
65    int FindI(const char *Name,int Default = 0);
66 //   int FindI(string Name,bool Default = 0) {return FindI(Name.c_str(),Default);};
67    bool FindB(const char *Name,bool Default = false);
68 //   bool FindB(string Name,bool Default = false) {return FindB(Name.c_str(),Default);};
69
70    inline void Set(string Name,string Value) {Set(Name.c_str(),Value);};
71    void Set(const char *Name,string Value);
72    void Set(const char *Name,int Value);   
73    
74    inline bool Exists(string Name) {return Exists(Name.c_str());};
75    bool Exists(const char *Name);
76       
77    inline const Item *Tree(const char *Name) {return Lookup(Name,false);};
78
79    void Dump();
80    
81    Configuration();
82 };
83
84 extern Configuration *_config;
85
86 bool ReadConfigFile(Configuration &Conf,string File);
87
88 #endif