/* +------------------------------------+ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev. * E-mail: * * * * Written by Craig Edwards, Craig McLure, and others. * This program is free but copyrighted software; see * the file COPYING for details. * * --------------------------------------------------- */ #include "inspircd_config.h" #include "base.h" #include #include #include #include #include "inspircd.h" #include "modules.h" #include "helperfuncs.h" const int bitfields[] = {1,2,4,8,16,32,64,128}; const int inverted_bitfields[] = {~1,~2,~4,~8,~16,~32,~64,~128}; extern time_t TIME; /* This is now a template in base.h * * bool Extensible::Extend(const std::string &key, char* p) * { * // only add an item if it doesnt already exist * if (this->Extension_Items.find(key) == this->Extension_Items.end()) * { * this->Extension_Items[key] = p; * log(DEBUG,"Extending object with item %s",key.c_str()); * return true; * } * // item already exists, return false * return false; * } */ bool Extensible::Shrink(const std::string &key) { /* map::size_type map::erase( const key_type& key ); * returns the number of elements removed, std::map * is single-associative so this should only be 0 or 1 */ if(this->Extension_Items.erase(key)) { log(DEBUG, "Shrinking object with item %s",key.c_str()); return true; } else { log(DEBUG, "Tried to shrink object with item %s but no items removed", key.c_str()); return false; } } char* Extensible::GetExt(const std::string &key) { /* This was calling ExtensibleStore::find() twice, * once to see if there was a value, and again to * get that value if it was there. Now we store * the iterator so we only have to search for it once. */ ExtensibleStore::iterator iter = this->Extension_Items.find(key); if(iter != this->Extension_Items.end()) { return iter->second; } else { return NULL; } } void Extensible::GetExtList(std::deque &list) { for (ExtensibleStore::iterator u = Extension_Items.begin(); u != Extension_Items.end(); u++) { list.push_back(u->first); } } void BoolSet::Set(int number) { this->bits |= bitfields[number]; } void BoolSet::Unset(int number) { this->bits &= inverted_bitfields[number]; } void BoolSet::Invert(int number) { this->bits ^= bitfields[number]; } bool BoolSet::Get(int number) { return ((this->bits | bitfields[number]) > 0); } bool BoolSet::operator==(BoolSet other) { return (this->bits == other.bits); } BoolSet BoolSet::operator|(BoolSet other) { BoolSet x(this->bits | other.bits); return x; } BoolSet BoolSet::operator&(BoolSet other) { BoolSet x(this->bits & other.bits); return x; } BoolSet::BoolSet() { this->bits = 0; } BoolSet::BoolSet(char bitmask) { this->bits = bitmask; } bool BoolSet::operator=(BoolSet other) { this->bits = other.bits; return true; }