00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef INCL_EVOLUTION_FILTER_CONFIG_NODE
00021 # define INCL_EVOLUTION_FILTER_CONFIG_NODE
00022
00023 #include <ConfigNode.h>
00024 #include <boost/shared_ptr.hpp>
00025 #include <boost/algorithm/string/case_conv.hpp>
00026 #include <boost/algorithm/string.hpp>
00027
00028 #include "SyncEvolutionUtil.h"
00029
00030 #include <map>
00031 #include <utility>
00032 #include <vector>
00033 #include <string>
00034 using namespace std;
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045 class FilterConfigNode : public ConfigNode {
00046 public:
00047
00048 class ConfigFilter : public map<string, string, Nocase<string> > {
00049 public:
00050
00051 operator string () const;
00052 };
00053
00054
00055 FilterConfigNode(const boost::shared_ptr<ConfigNode> &node,
00056 const ConfigFilter &filter = ConfigFilter());
00057
00058
00059 FilterConfigNode(const boost::shared_ptr<const ConfigNode> &node,
00060 const ConfigFilter &filter = ConfigFilter());
00061
00062 virtual string getName() const { return m_readOnlyNode->getName(); }
00063
00064
00065 void addFilter(const string &property,
00066 const string &value);
00067
00068
00069 void setFilter(const ConfigFilter &filter);
00070 const ConfigFilter &getFilter() const { return m_filter; }
00071
00072
00073 virtual void flush();
00074 virtual string readProperty(const string &property) const;
00075 virtual void setProperty(const string &property,
00076 const string &value,
00077 const string &comment = "",
00078 const string *defValue = NULL);
00079 virtual void readProperties(map<string, string> &props) const;
00080 virtual void removeProperty(const string &property);
00081 virtual bool exists() const { return m_readOnlyNode->exists(); }
00082
00083 private:
00084 ConfigFilter m_filter;
00085 boost::shared_ptr<ConfigNode> m_node;
00086 boost::shared_ptr<const ConfigNode> m_readOnlyNode;
00087 };
00088
00089 #endif