// -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- // vim:tabstop=4:shiftwidth=4:expandtab: /* * Copyright (C) 2004 Wu Yongwei <adah at users dot sourceforge dot net> * * This software is provided 'as-is', without any express or implied * warranty. In no event will the authors be held liable for any * damages arising from the use of this software. * * Permission is granted to anyone to use this software for any purpose, * including commercial applications, and to alter it and redistribute * it freely, subject to the following restrictions: * * 1. The origin of this software must not be misrepresented; you must * not claim that you wrote the original software. If you use this * software in a product, an acknowledgment in the product * documentation would be appreciated but is not required. * 2. Altered source versions must be plainly marked as such, and must * not be misrepresented as being the original software. * 3. This notice may not be removed or altered from any source * distribution. * * This file is part of Stones of Nvwa: * http://sourceforge.net/projects/nvwa * */ /** * @file static_mem_pool.cpp * * Non-template and non-inline code for the `static' memory pool. * * @version 1.3, 2004/07/26 * @author Wu Yongwei * */ #include <algorithm> #include "static_mem_pool.h" struct delete_object { template <typename _Pointer> void operator()(_Pointer __ptr) const { delete __ptr; } }; static_mem_pool_set::static_mem_pool_set() { _STATIC_MEM_POOL_TRACE(false, "The static_mem_pool_set is created"); } static_mem_pool_set::~static_mem_pool_set() { lock __guard; std::for_each(_M_memory_pool_set.begin(), _M_memory_pool_set.end(), delete_object()); _STATIC_MEM_POOL_TRACE(false, "The static_mem_pool_set is destroyed"); } static_mem_pool_set& static_mem_pool_set::instance() { lock __guard; static static_mem_pool_set _S_instance; return _S_instance; } void static_mem_pool_set::recycle() { lock __guard; _STATIC_MEM_POOL_TRACE(false, "Memory pools are being recycled"); std::set<mem_pool_base*>::iterator __end = _M_memory_pool_set.end(); for (std::set<mem_pool_base*>::iterator __i = _M_memory_pool_set.begin(); __i != __end; ++__i) { (*__i)->recycle(); } } void static_mem_pool_set::add(mem_pool_base* __memory_pool_p) { lock __guard; _M_memory_pool_set.insert(__memory_pool_p); }