X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Ffilter.hpp;h=c2855bd2f00f14fe0634d1747f7d220e2d90e4dc;hb=7c5a169c1bcccae466bf78af1fae376d81812c43;hp=faaefc61d02a9a9d2205b6a7fe8c04913889cdf5;hpb=f82b19f2b93707657fee804bd1242f2548d51ada;p=metaproxy-moved-to-github.git diff --git a/src/filter.hpp b/src/filter.hpp index faaefc6..c2855bd 100644 --- a/src/filter.hpp +++ b/src/filter.hpp @@ -1,4 +1,4 @@ -/* $Id: filter.hpp,v 1.4 2005-10-15 14:09:09 adam Exp $ +/* $Id: filter.hpp,v 1.10 2005-12-10 09:59:10 adam Exp $ Copyright (c) 2005, Index Data. %LICENSE% @@ -7,7 +7,9 @@ #ifndef FILTER_HPP #define FILTER_HPP +#include #include +#include namespace yp2 { @@ -19,41 +21,26 @@ 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 yp2_filter_struct { + int ver; + yp2::filter::Base* (*creator)(); +}; + #endif /* * Local variables: