123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- // -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*-
- // vim:tabstop=4:shiftwidth=4:expandtab:
- /*
- * Copyright (C) 2004-2008 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 acknowledgement 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 cont_ptr_utils.h
- * \ingroup QxMemLeak
- *
- * Utility functors for containers of pointers (adapted from Scott
- * Meyers' <em>Effective STL</em>).
- *
- * \version 1.4, 2007/09/12
- * \author Wu Yongwei
- *
- */
- #ifndef QT_NO_DEBUG
- #ifndef _QX_MODE_RELEASE
- #if _QX_USE_MEM_LEAK_DETECTION
- #ifndef _CONT_PTR_UTILS_H
- #define _CONT_PTR_UTILS_H
- #ifdef _MSC_VER
- #pragma once
- #endif
- namespace qx {
- namespace memory {
- /**
- * Functor to return objects pointed by a container of pointers.
- *
- * A typical usage might be like:
- * @code
- * vector<Object*> v;
- * ...
- * transform(v.begin(), v.end(),
- * ostream_iterator<Object>(cout, " "),
- * dereference());
- * @endcode
- */
- struct QX_DLL_EXPORT dereference
- {
- template <typename _Tp>
- const _Tp& operator()(const _Tp* __ptr) const
- {
- return *__ptr;
- }
- };
- /**
- * Functor to compare objects pointed by a container of pointers.
- *
- * @code
- * vector<Object*> v;
- * ...
- * sort(v.begin(), v.end(), dereference_less());
- * @endcode
- * or
- * @code
- * set<Object*, dereference_less> s;
- * @endcode
- */
- struct QX_DLL_EXPORT dereference_less
- {
- template <typename _Pointer>
- bool operator()(_Pointer __ptr1, _Pointer __ptr2) const
- {
- return *__ptr1 < *__ptr2;
- }
- };
- /**
- * Functor to delete objects pointed by a container of pointers.
- *
- * A typical usage might be like:
- * @code
- * list<Object*> l;
- * ...
- * for_each(l.begin(), l.end(), delete_object());
- * @endcode
- */
- struct QX_DLL_EXPORT delete_object
- {
- template <typename _Pointer>
- void operator()(_Pointer __ptr) const
- {
- delete __ptr;
- }
- };
- /**
- * Functor to output objects pointed by a container of pointers.
- *
- * A typical usage might be like:
- * @code
- * list<Object*> l;
- * ...
- * for_each(l.begin(), l.end(), output_object<ostream>(cout, " "));
- * @endcode
- */
- template <typename _OutputStrm, typename _StringType = const char*>
- struct output_object
- {
- output_object(_OutputStrm& __outs, const _StringType& __sep)
- : _M_outs(__outs), _M_sep(__sep)
- {}
- template <typename _Tp>
- void operator()(const _Tp* __ptr) const
- {
- _M_outs << *__ptr << _M_sep;
- }
- private:
- _OutputStrm& _M_outs;
- _StringType _M_sep;
- };
- } // namespace memory
- } // namespace qx
- #endif // _CONT_PTR_UTILS_H
- #endif // _QX_USE_MEM_LEAK_DETECTION
- #endif // _QX_MODE_RELEASE
- #endif // QT_NO_DEBUG
|