source: src/Helpers/MemDebug.hpp@ a2392b

Last change on this file since a2392b was a2392b, checked in by Frederik Heber <heber@…>, 14 years ago

FIX: boost/serialization added to includes before Memory.

  • boost::serialization seems to have a bug with overloaded new, hence it has to be included before.
  • Property mode set to 100644
File size: 3.0 KB
Line 
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
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
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>
56#include <boost/optional.hpp>
57#include <boost/shared_ptr.hpp>
58#include <boost/function.hpp>
59// serialization has bug with overloaded new, see https://svn.boost.org/trac/boost/ticket/3400
60#include <boost/serialization/access.hpp>
61
62
63namespace Memory {
64
65 /**
66 * Displays a short summary of the memory state.
67 */
68 void getState();
69 void dumpMemory(std::ostream&);
70
71 void _ignore(void*);
72
73 /**
74 * Use this to disable memory for a certain pointer on the heap.
75 * This is useful for pointers which should live over the run of the
76 * program, and which are deleted automatically at the end. Usually these
77 * pointers should be wrapped inside some kind of smart pointer to
78 * ensure destruction at the end.
79 */
80 template <typename T>
81 T *ignore(T* ptr){
82 _ignore((void*)ptr);
83 return ptr;
84 }
85}
86#ifdef __GNUC__
87void *operator new (size_t nbytes,const char* file, int line, const char* func) throw(std::bad_alloc);
88void *operator new[] (size_t nbytes,const char* file, int line, const char* func) throw(std::bad_alloc);
89#else
90void *operator new (size_t nbytes,const char* file, int line) throw(std::bad_alloc);
91void *operator new[] (size_t nbytes,const char* file, int line) throw(std::bad_alloc);
92#endif
93void operator delete (void *ptr,const char*, int) throw();
94void operator delete[] (void *ptr,const char*, int) throw();
95
96
97
98/**
99 * This macro replaces all occurences of the keyword new with a replaced
100 * version that allows tracking.
101 */
102#ifdef __GNUC__
103#define new new(__FILE__,__LINE__,__PRETTY_FUNCTION__)
104#else
105#define new new(__FILE__,__LINE__)
106#endif
107
108#else
109
110#include <iosfwd>
111
112// memory debugging was disabled
113
114namespace Memory {
115 inline void getState(){};
116
117 inline void dumpMemory(std::ostream&){};
118
119 template <typename T>
120 inline T *ignore(T* ptr){
121 return ptr;
122 }
123}
124
125#endif
126
127
128#endif /* MEMDEBUG_HPP_ */
Note: See TracBrowser for help on using the repository browser.