/* +------------------------------------+ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * * InspIRCd: (C) 2002-2009 InspIRCd Development Team * See: http://wiki.inspircd.org/Credits * * This program is free but copyrighted software; see * the file COPYING for details. * * --------------------------------------------------- */ /* $Core */ #include "inspircd_config.h" #include "base.h" #include #include "inspircd.h" const int bitfields[] = {1,2,4,8,16,32,64,128}; const int inverted_bitfields[] = {~1,~2,~4,~8,~16,~32,~64,~128}; std::map Extensible::extension_types; classbase::classbase() { } bool classbase::cull() { return true; } classbase::~classbase() { } refcountbase::refcountbase() : refcount(0) { } bool refcountbase::cull() { return (refcount == 0); } refcountbase::~refcountbase() { } ExtensionItem::ExtensionItem(const std::string& Key, Module* mod) : key(Key), owner(mod) { } ExtensionItem::~ExtensionItem() { } void* ExtensionItem::get_raw(const Extensible* container) { ExtensibleStore::const_iterator i = container->extensions.find(key); if (i == container->extensions.end()) return NULL; return i->second; } void* ExtensionItem::set_raw(Extensible* container, void* value) { std::pair rv = container->extensions.insert(std::make_pair(key, value)); if (rv.second) { return NULL; } else { void* old = rv.first->second; rv.first->second = value; return old; } } void* ExtensionItem::unset_raw(Extensible* container) { ExtensibleStore::iterator i = container->extensions.find(key); if (i == container->extensions.end()) return NULL; void* rv = i->second; container->extensions.erase(i); return rv; } bool Extensible::Register(ExtensionItem* item) { return Extensible::extension_types.insert(std::make_pair(item->key, item)).second; } std::vector Extensible::BeginUnregister(Module* module) { std::vector rv; ExtensibleTypes::iterator i = extension_types.begin(); while (i != extension_types.end()) { ExtensibleTypes::iterator c = i++; if (c->second->owner == module) { rv.push_back(c->second); extension_types.erase(c); } } return rv; } void Extensible::doUnhookExtensions(const std::vector& toRemove) { for(std::vector::const_iterator i = toRemove.begin(); i != toRemove.end(); i++) { ExtensibleStore::iterator e = extensions.find((**i).key); if (e != extensions.end()) { (**i).free(e->second); extensions.erase(e); } } } Extensible::~Extensible() { for(ExtensibleStore::iterator i = extensions.begin(); i != extensions.end(); ++i) { ExtensionItem* type = GetItem(i->first); if (type) type->free(i->second); else if (ServerInstance && ServerInstance->Logs) ServerInstance->Logs->Log("BASE", ERROR, "Extension type %s is not registered", i->first.c_str()); } } LocalExtItem::LocalExtItem(const std::string& Key, Module* mod) : ExtensionItem(Key, mod) { } LocalExtItem::~LocalExtItem() { } std::string LocalExtItem::serialize(SerializeFormat format, const Extensible* container, void* item) { return ""; } void LocalExtItem::unserialize(SerializeFormat format, Extensible* container, const std::string& value) { } LocalStringExt::LocalStringExt(const std::string& Key, Module* Owner) : SimpleExtItem(Key, Owner) { } LocalStringExt::~LocalStringExt() { } std::string LocalStringExt::serialize(SerializeFormat format, const Extensible* container, void* item) { if (item && format == FORMAT_USER) return *static_cast(item); return ""; } LocalIntExt::LocalIntExt(const std::string& Key, Module* mod) : LocalExtItem(Key, mod) { } LocalIntExt::~LocalIntExt() { } std::string LocalIntExt::serialize(SerializeFormat format, const Extensible* container, void* item) { if (format != FORMAT_USER) return ""; return ConvToStr(reinterpret_cast(item)); } intptr_t LocalIntExt::get(const Extensible* container) { return reinterpret_cast(get_raw(container)); } intptr_t LocalIntExt::set(Extensible* container, intptr_t value) { if (value) return reinterpret_cast(set_raw(container, reinterpret_cast(value))); else return reinterpret_cast(unset_raw(container)); } void LocalIntExt::free(void*) { } StringExtItem::StringExtItem(const std::string& Key, Module* mod) : ExtensionItem(Key, mod) { } StringExtItem::~StringExtItem() { } std::string* StringExtItem::get(const Extensible* container) { return static_cast(get_raw(container)); } std::string StringExtItem::serialize(SerializeFormat format, const Extensible* container, void* item) { return item ? *static_cast(item) : ""; } void StringExtItem::unserialize(SerializeFormat format, Extensible* container, const std::string& value) { if (value.empty()) unset(container); else set(container, value); } void StringExtItem::set(Extensible* container, const std::string& value) { void* old = set_raw(container, new std::string(value)); delete static_cast(old); } void StringExtItem::unset(Extensible* container) { void* old = unset_raw(container); delete static_cast(old); } void StringExtItem::free(void* item) { delete static_cast(item); }