/* * Copyright (C) 1996-2018 The Squid Software Foundation and contributors * * Squid software is distributed under GPLv2+ license and includes * contributions from numerous individuals and organizations. * Please see the COPYING and CONTRIBUTORS files for details. */ #ifndef SQUID_ACLSTRATEGISED_H #define SQUID_ACLSTRATEGISED_H #include "acl/Acl.h" #include "acl/Data.h" #include "acl/FilledChecklist.h" #include "acl/Strategy.h" template class ACLStrategised : public ACL { public: typedef M MatchType; void *operator new(size_t); void operator delete(void *); ~ACLStrategised(); ACLStrategised(ACLData *, ACLStrategy *, char const *, const ACLFlag flags[] = ACLFlags::NoFlags); ACLStrategised (ACLStrategised const &); ACLStrategised &operator= (ACLStrategised const &); virtual char const *typeString() const; virtual bool requiresRequest() const {return matcher->requiresRequest();} virtual bool requiresReply() const {return matcher->requiresReply();} virtual void prepareForUse() { data->prepareForUse();} virtual void parse(); virtual int match(ACLChecklist *checklist); virtual int match (M const &); virtual SBufList dump() const; virtual bool empty () const; virtual bool valid () const; virtual ACL *clone()const; private: static MemAllocator *Pool; ACLData *data; char const *type_; ACLStrategy *matcher; }; /* implementation follows */ template MemAllocator *ACLStrategised::Pool = NULL; template void * ACLStrategised::operator new (size_t byteCount) { /* derived classes with different sizes must implement their own new */ assert (byteCount == sizeof (ACLStrategised)); if (!Pool) Pool = memPoolCreate("ACLStrategised", sizeof (ACLStrategised)); return Pool->alloc(); } template void ACLStrategised::operator delete (void *address) { Pool->freeOne(address); } template ACLStrategised::~ACLStrategised() { delete data; } template ACLStrategised::ACLStrategised(ACLData *newData, ACLStrategy *theStrategy, char const *theType, const ACLFlag flgs[]) : ACL(flgs), data (newData), type_(theType), matcher(theStrategy) {} template ACLStrategised::ACLStrategised (ACLStrategised const &old) : data (old.data->clone()), type_(old.type_), matcher (old.matcher) {} template ACLStrategised & ACLStrategised::operator= (ACLStrategised const &rhs) { data = rhs.data->clone(); type_ = rhs.type_; matcher = rhs.matcher; return *this; } template char const * ACLStrategised::typeString() const { return type_; } template void ACLStrategised::parse() { data->parse(); } template bool ACLStrategised::empty() const { return data->empty(); } template int ACLStrategised::match(ACLChecklist *cl) { ACLFilledChecklist *checklist = dynamic_cast(cl); assert(checklist); return matcher->match(data, checklist, flags); } template int ACLStrategised::match(MatchType const &toFind) { return data->match(toFind); } template SBufList ACLStrategised::dump() const { return data->dump(); } template bool ACLStrategised::valid () const { return matcher->valid(); } template ACL * ACLStrategised::clone() const { return new ACLStrategised(*this); } #endif /* SQUID_ACLSTRATEGISED_H */