X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Ffilter.hpp;h=b4412849310923dfd9520cd7da1a159cdd8c84fd;hb=c15e5107a199363ad87e242142553b48a69f2476;hp=73bf2ca1aa4a6152d8a53a0a8c8aaa4a19aef295;hpb=b84218609efb976d5b5270bd9e95a3c421af3a13;p=metaproxy-moved-to-github.git diff --git a/src/filter.hpp b/src/filter.hpp index 73bf2ca..b441284 100644 --- a/src/filter.hpp +++ b/src/filter.hpp @@ -1,10 +1,18 @@ +/* $Id: filter.hpp,v 1.16 2006-03-16 10:40:59 adam Exp $ + Copyright (c) 2005-2006, Index Data. + +%LICENSE% + */ #ifndef FILTER_HPP #define FILTER_HPP +#include #include +#include +#include "xmlutil.hpp" -namespace yp2 { +namespace metaproxy_1 { class Package; @@ -14,46 +22,32 @@ namespace yp2 { virtual ~Base(){}; ///sends Package off to next Filter, returns altered Package - virtual void process(Package & package) const { + virtual void process(Package & package) const = 0; + + virtual void configure(const xmlNode * ptr); + }; + + class FilterException : public std::runtime_error { + public: + FilterException(const std::string message) + : std::runtime_error("FilterException: " + message){ }; - virtual void configure(){}; - - /// get function - right val in assignment - std::string name() const { - return m_name; - } - - /// set function - left val in assignment - std::string & name() { - return m_name; - } - - /// set function - can be chained - Base & name(const std::string & name){ - m_name = name; - return *this; - } - - private: - std::string m_name; }; } - - class FilterException : public std::runtime_error { - public: - FilterException(const std::string message) - : std::runtime_error("FilterException: " + message){ - }; - }; - - } +struct metaproxy_1_filter_struct { + int ver; + const char *type; + metaproxy_1::filter::Base* (*creator)(); +}; + #endif /* * Local variables: * c-basic-offset: 4 * indent-tabs-mode: nil + * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */