source: src/CodePatterns/MemDebug.hpp@ c362a4

Last change on this file since c362a4 was 2f40706, checked in by Frederik Heber <heber@…>, 13 years ago

MemDebug now has boost/archive/iserializer.hpp included before all else.

  • Property mode set to 100644
File size: 3.8 KB
RevLine 
[a80f419]1/*
2 * MemDebug.hpp
3 *
4 * Created on: Apr 28, 2010
5 * Author: crueger
6 */
7
8#ifndef MEMDEBUG_HPP_
9#define MEMDEBUG_HPP_
10
[70672e3]11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
[a80f419]16/**
17 * @file
18 * This module allows easy automatic memory tracking. Link this module to replace the
19 * operators new, new[], delete and delete[] with custom versions that add tracking
20 * information to allocated blocks.
21 *
22 * All tracking is done in O(1) for new and delete operators. Summaries for the
23 * used memory take O(N), where N is the number of currently allocated memory chunks.
24 *
25 * To use full tracking including file name and line number include this file in
26 * your sourcefiles.
27 */
28
29// Set all flags in a way that makes sense
30
31// NDEBUG implies NO_MEMDEBUG
32#ifdef NDEBUG
33# ifndef NO_MEMDEBUG
34# define NO_MEMDEBUG
35# endif
36#endif
37
38// NO_MEMDEBUG and MEMDEBUG are mutually exclusive, but at least one must be set
39#ifdef NO_MEMDEBUG
40# ifdef MEMDEBUG
41# undef MEMDEBUG
42# endif
43#else
44# ifndef MEMDEBUG
45# define MEMDEBUG
46# endif
47#endif
48
49#ifdef MEMDEBUG
50
51#include <new>
52
53// some light header files, that do weird new stuff and therefore need
54// to be loaded before the define
55#include <string>
[26c242]56#if defined HAVE_BOOST_OPTIONAL_HPP || defined HAVE_BOOST_THREAD_HPP
[a80f419]57#include <boost/optional.hpp>
[26c242]58#endif
59#if defined HAVE_BOOST_SHARED_PTR_HPP || defined HAVE_BOOST_THREAD_HPP
[a80f419]60#include <boost/shared_ptr.hpp>
[63e9ca]61#include <boost/make_shared.hpp>
[26c242]62#endif
63#ifdef HAVE_BOOST_BIND_HPP
64#include <boost/bind.hpp>
65#endif
66#if defined HAVE_BOOST_FUNCTION_HPP || defined HAVE_BOOST_THREAD_HPP
[a80f419]67#include <boost/function.hpp>
[26c242]68#endif
69#ifdef HAVE_BOOST_ARCHIVE_TEXT_OARCHIVE_HPP
[a2392b]70// serialization has bug with overloaded new, see https://svn.boost.org/trac/boost/ticket/3400
71#include <boost/serialization/access.hpp>
[2f40706]72#include <boost/archive/detail/iserializer.hpp>
[26c242]73#endif
74#if defined HAVE_VALARRAY || defined HAVE_BOOST_ARCHIVE_TEXT_OARCHIVE_HPP
[cc78ae]75// valarray uses specific new as well
76#include <valarray>
[26c242]77#endif
[2f40706]78#if defined HAVE_BOOST_MULTI_ARRAY_HPP || defined HAVE_BOOST_ASIO_HPP
[e7352a5]79// multiarray uses type trait has_new_operator.hpp
80#include <boost/type_traits/has_new_operator.hpp>
81#endif
[2f40706]82#if defined HAVE_BOOST_ASIO_HPP
83// boost asio uses own allocator
84#include <boost/serialization/shared_ptr_132.hpp>
85#endif
[a80f419]86
87namespace Memory {
88
89 /**
90 * Displays a short summary of the memory state.
91 */
92 void getState();
93 void dumpMemory(std::ostream&);
94
95 void _ignore(void*);
96
97 /**
98 * Use this to disable memory for a certain pointer on the heap.
99 * This is useful for pointers which should live over the run of the
100 * program, and which are deleted automatically at the end. Usually these
101 * pointers should be wrapped inside some kind of smart pointer to
102 * ensure destruction at the end.
103 */
104 template <typename T>
105 T *ignore(T* ptr){
106 _ignore((void*)ptr);
107 return ptr;
108 }
109}
110#ifdef __GNUC__
111void *operator new (size_t nbytes,const char* file, int line, const char* func) throw(std::bad_alloc);
112void *operator new[] (size_t nbytes,const char* file, int line, const char* func) throw(std::bad_alloc);
113#else
114void *operator new (size_t nbytes,const char* file, int line) throw(std::bad_alloc);
115void *operator new[] (size_t nbytes,const char* file, int line) throw(std::bad_alloc);
116#endif
117void operator delete (void *ptr,const char*, int) throw();
118void operator delete[] (void *ptr,const char*, int) throw();
119
120
121
122/**
123 * This macro replaces all occurences of the keyword new with a replaced
124 * version that allows tracking.
125 */
126#ifdef __GNUC__
127#define new new(__FILE__,__LINE__,__PRETTY_FUNCTION__)
128#else
129#define new new(__FILE__,__LINE__)
130#endif
131
132#else
133
134#include <iosfwd>
135
136// memory debugging was disabled
137
138namespace Memory {
139 inline void getState(){};
140
141 inline void dumpMemory(std::ostream&){};
142
143 template <typename T>
144 inline T *ignore(T* ptr){
145 return ptr;
146 }
147}
148
149#endif
150
151
152#endif /* MEMDEBUG_HPP_ */
Note: See TracBrowser for help on using the repository browser.