]> git.saurik.com Git - wxWidgets.git/blame - include/wx/debug.h
Remove some old redundant code
[wxWidgets.git] / include / wx / debug.h
CommitLineData
993df040
VZ
1/////////////////////////////////////////////////////////////////////////////
2// Name: wx/debug.h
3// Purpose: Misc debug functions and macros
4// Author: Vadim Zeitlin
5// Created: 29/01/98
993df040
VZ
6// Copyright: (c) 1998-2009 Vadim Zeitlin <vadim@wxwidgets.org>
7// Licence: wxWindows licence
8/////////////////////////////////////////////////////////////////////////////
e0c749a7 9
993df040
VZ
10#ifndef _WX_DEBUG_H_
11#define _WX_DEBUG_H_
c801d85f 12
bd362275 13#if !defined(__WXWINCE__)
993df040
VZ
14 #include <assert.h>
15#endif // systems without assert.h
c801d85f 16
993df040 17#include <limits.h> // for CHAR_BIT used below
c801d85f 18
993df040 19#include "wx/chartype.h" // for __TFILE__ and wxChar
a6ebdba6 20#include "wx/cpp.h" // for __WXFUNCTION__
e9c4f54e 21#include "wx/dlimpexp.h" // for WXDLLIMPEXP_FWD_BASE
9e3d3318 22
657a8a35
VZ
23class WXDLLIMPEXP_FWD_BASE wxString;
24class WXDLLIMPEXP_FWD_BASE wxCStrData;
25
993df040
VZ
26// ----------------------------------------------------------------------------
27// Defines controlling the debugging macros
28// ----------------------------------------------------------------------------
8b0bd21b 29
657a8a35
VZ
30/*
31 wxWidgets can be built with several different levels of debug support
32 specified by the value of wxDEBUG_LEVEL constant:
33
34 0: No assertion macros at all, this should only be used when optimizing
35 for resource-constrained systems (typically embedded ones).
36 1: Default level, most of the assertions are enabled.
37 2: Maximal (at least for now): asserts which are "expensive"
38 (performance-wise) or only make sense for finding errors in wxWidgets
39 itself, as opposed to bugs in applications using it, are also enabled.
657a8a35
VZ
40 */
41
7d9550df
VZ
42// unless wxDEBUG_LEVEL is predefined (by configure or via wx/setup.h under
43// Windows), use the default
44#if !defined(wxDEBUG_LEVEL)
45 #define wxDEBUG_LEVEL 1
46#endif // !defined(wxDEBUG_LEVEL)
47
48/*
49 __WXDEBUG__ is defined when wxDEBUG_LEVEL != 0. This is done mostly for
50 compatibility but it also provides a simpler way to check if asserts and
51 debug logging is enabled at all.
52 */
53#if wxDEBUG_LEVEL > 0
8b0bd21b
VZ
54 #ifndef __WXDEBUG__
55 #define __WXDEBUG__
7d9550df
VZ
56 #endif
57#else
8b0bd21b 58 #undef __WXDEBUG__
7d9550df 59#endif
8b0bd21b 60
7d9550df
VZ
61// Finally there is also a very old WXDEBUG macro not used anywhere at all, it
62// is only defined for compatibility.
8b0bd21b
VZ
63#ifdef __WXDEBUG__
64 #if !defined(WXDEBUG) || !WXDEBUG
65 #undef WXDEBUG
66 #define WXDEBUG 1
993df040
VZ
67 #endif // !WXDEBUG
68#endif // __WXDEBUG__
e0c749a7 69
993df040 70// ----------------------------------------------------------------------------
657a8a35 71// Handling assertion failures
993df040
VZ
72// ----------------------------------------------------------------------------
73
657a8a35
VZ
74/*
75 Type for the function called in case of assert failure, see
76 wxSetAssertHandler().
77 */
78typedef void (*wxAssertHandler_t)(const wxString& file,
79 int line,
80 const wxString& func,
81 const wxString& cond,
82 const wxString& msg);
83
84#if wxDEBUG_LEVEL
85
86// the global assert handler function, if it is NULL asserts don't check their
87// conditions
88extern WXDLLIMPEXP_DATA_BASE(wxAssertHandler_t) wxTheAssertHandler;
89
90/*
91 Sets the function to be called in case of assertion failure.
92
93 The default assert handler forwards to wxApp::OnAssertFailure() whose
94 default behaviour is, in turn, to show the standard assertion failure
95 dialog if a wxApp object exists or shows the same dialog itself directly
96 otherwise.
97
98 While usually it is enough -- and more convenient -- to just override
99 OnAssertFailure(), to handle all assertion failures, including those
72516be4 100 occurring even before wxApp object creation or after its destruction you
657a8a35
VZ
101 need to provide your assertion handler function.
102
103 This function also provides a simple way to disable all asserts: simply
104 pass NULL pointer to it. Doing this will result in not even evaluating
105 assert conditions at all, avoiding almost all run-time cost of asserts.
106
107 Notice that this function is not MT-safe, so you should call it before
108 starting any other threads.
109
110 The return value of this function is the previous assertion handler. It can
111 be called after any pre-processing by your handler and can also be restored
112 later if you uninstall your handler.
113 */
114inline wxAssertHandler_t wxSetAssertHandler(wxAssertHandler_t handler)
115{
116 const wxAssertHandler_t old = wxTheAssertHandler;
117 wxTheAssertHandler = handler;
118 return old;
119}
120
7d9550df
VZ
121/*
122 Reset the default assert handler.
123
124 This may be used to enable asserts, which are disabled by default in this
125 case, for programs built in release build (NDEBUG defined).
126 */
127extern void WXDLLIMPEXP_BASE wxSetDefaultAssertHandler();
128
657a8a35
VZ
129#else // !wxDEBUG_LEVEL
130
72516be4 131// provide empty stubs in case assertions are completely disabled
993df040 132//
657a8a35
VZ
133// NB: can't use WXUNUSED() here as we're included from wx/defs.h before it is
134// defined
135inline wxAssertHandler_t wxSetAssertHandler(wxAssertHandler_t /* handler */)
136{
137 return NULL;
138}
139
7d9550df
VZ
140inline void wxSetDefaultAssertHandler() { }
141
657a8a35
VZ
142#endif // wxDEBUG_LEVEL/!wxDEBUG_LEVEL
143
144// simply a synonym for wxSetAssertHandler(NULL)
145inline void wxDisableAsserts() { wxSetAssertHandler(NULL); }
146
7d9550df
VZ
147/*
148 A macro which disables asserts for applications compiled in release build.
149
e4431849 150 By default, wxIMPLEMENT_APP (or rather wxIMPLEMENT_WXWIN_MAIN) disable the
7d9550df
VZ
151 asserts in the applications compiled in the release build by calling this.
152 It does nothing if NDEBUG is not defined.
153 */
154#ifdef NDEBUG
155 #define wxDISABLE_ASSERTS_IN_RELEASE_BUILD() wxDisableAsserts()
156#else
157 #define wxDISABLE_ASSERTS_IN_RELEASE_BUILD()
158#endif
159
657a8a35
VZ
160#if wxDEBUG_LEVEL
161
162/*
163 wxOnAssert() is used by the debugging macros defined below. Different
ebd98179 164 overloads are needed because these macros can be used with or without wxT().
657a8a35
VZ
165
166 All of them are implemented in src/common/appcmn.cpp and unconditionally
167 call wxTheAssertHandler so the caller must check that it is non-NULL
168 (assert macros do it).
169 */
749b01f0 170
0accd1cf 171#if wxUSE_UNICODE
657a8a35
VZ
172
173// these overloads are the ones typically used by debugging macros: we have to
ebd98179 174// provide wxChar* msg version because it's common to use wxT() in the macros
657a8a35
VZ
175// and finally, we can't use const wx(char)* msg = NULL, because that would
176// be ambiguous
177//
178// also notice that these functions can't be inline as wxString is not defined
179// yet (and can't be as wxString code itself may use assertions)
2b760b6b 180extern WXDLLIMPEXP_BASE void wxOnAssert(const char *file,
657a8a35
VZ
181 int line,
182 const char *func,
183 const char *cond);
184
2b760b6b 185extern WXDLLIMPEXP_BASE void wxOnAssert(const char *file,
657a8a35
VZ
186 int line,
187 const char *func,
188 const char *cond,
189 const char *msg);
190
2b760b6b 191extern WXDLLIMPEXP_BASE void wxOnAssert(const char *file,
657a8a35
VZ
192 int line,
193 const char *func,
194 const char *cond,
b625fff5 195 const wxChar *msg) ;
28efe654 196#endif /* wxUSE_UNICODE */
0accd1cf 197
657a8a35
VZ
198// this version is for compatibility with wx 2.8 Unicode build only, we don't
199// use it ourselves any more except in ANSI-only build in which case it is all
200// we need
2b760b6b 201extern WXDLLIMPEXP_BASE void wxOnAssert(const wxChar *file,
657a8a35
VZ
202 int line,
203 const char *func,
204 const wxChar *cond,
205 const wxChar *msg = NULL);
206
207// these overloads work when msg passed to debug macro is a string and we
208// also have to provide wxCStrData overload to resolve ambiguity which would
209// otherwise arise from wxASSERT( s.c_str() )
2b760b6b 210extern WXDLLIMPEXP_BASE void wxOnAssert(const wxString& file,
657a8a35
VZ
211 int line,
212 const wxString& func,
213 const wxString& cond,
214 const wxString& msg);
215
2b760b6b 216extern WXDLLIMPEXP_BASE void wxOnAssert(const wxString& file,
657a8a35
VZ
217 int line,
218 const wxString& func,
219 const wxString& cond);
220
2b760b6b 221extern WXDLLIMPEXP_BASE void wxOnAssert(const char *file,
657a8a35
VZ
222 int line,
223 const char *func,
224 const char *cond,
225 const wxCStrData& msg);
226
2b760b6b 227extern WXDLLIMPEXP_BASE void wxOnAssert(const char *file,
657a8a35
VZ
228 int line,
229 const char *func,
230 const char *cond,
231 const wxString& msg);
232
233#endif // wxDEBUG_LEVEL
749b01f0 234
c801d85f 235
657a8a35
VZ
236// ----------------------------------------------------------------------------
237// Debugging macros
238// ----------------------------------------------------------------------------
34cbe514 239
657a8a35
VZ
240/*
241 Assertion macros: check if the condition is true and call assert handler
242 (which will by default notify the user about failure) if it isn't.
8b0bd21b 243
657a8a35
VZ
244 wxASSERT and wxFAIL macros as well as wxTrap() function do nothing at all
245 if wxDEBUG_LEVEL is 0 however they do check their conditions at default
246 debug level 1, unlike the previous wxWidgets versions.
c801d85f 247
657a8a35
VZ
248 wxASSERT_LEVEL_2 is meant to be used for "expensive" asserts which should
249 normally be disabled because they have a big impact on performance and so
250 this macro only does anything if wxDEBUG_LEVEL >= 2.
251 */
252#if wxDEBUG_LEVEL
55fd62c1
VZ
253 // wxTrap() can be used to break into the debugger unconditionally
254 // (assuming the program is running under debugger, of course).
255 //
256 // If possible, we prefer to define it as a macro rather than as a function
257 // to open the debugger at the position where we trapped and not inside the
258 // trap function itself which is not very useful.
739c5499 259 #if wxCHECK_VISUALC_VERSION(7)
55fd62c1
VZ
260 #define wxTrap() __debugbreak()
261 #else
262 extern WXDLLIMPEXP_BASE void wxTrap();
263 #endif // Win VisualC
264
265 // Global flag used to indicate that assert macros should call wxTrap(): it
266 // is set by the default assert handler if the user answers yes to the
267 // question of whether to trap.
268 extern WXDLLIMPEXP_DATA_BASE(bool) wxTrapInAssert;
269
270 // This macro checks if the condition is true and calls the assert handler
271 // with the provided message if it isn't and finally traps if the special
272 // flag indicating that it should do it was set by the handler.
657a8a35 273 //
55fd62c1
VZ
274 // Notice that we don't use the handler return value for compatibility
275 // reasons (if we changed its return type, we'd need to change wxApp::
276 // OnAssertFailure() too which would break user code overriding it), hence
277 // the need for the ugly global flag.
657a8a35 278 #define wxASSERT_MSG(cond, msg) \
55fd62c1
VZ
279 wxSTATEMENT_MACRO_BEGIN \
280 if ( wxTheAssertHandler && !(cond) && \
281 (wxOnAssert(__FILE__, __LINE__, __WXFUNCTION__, \
282 #cond, msg), wxTrapInAssert) ) \
283 { \
284 wxTrapInAssert = false; \
285 wxTrap(); \
286 } \
287 wxSTATEMENT_MACRO_END
657a8a35
VZ
288
289 // a version without any additional message, don't use unless condition
290 // itself is fully self-explanatory
291 #define wxASSERT(cond) wxASSERT_MSG(cond, (const char*)NULL)
292
293 // wxFAIL is a special form of assert: it always triggers (and so is
294 // usually used in normally unreachable code)
55fd62c1
VZ
295 #define wxFAIL_COND_MSG(cond, msg) \
296 wxSTATEMENT_MACRO_BEGIN \
297 if ( wxTheAssertHandler && \
298 (wxOnAssert(__FILE__, __LINE__, __WXFUNCTION__, \
0a890608 299 cond, msg), wxTrapInAssert) ) \
55fd62c1
VZ
300 { \
301 wxTrapInAssert = false; \
302 wxTrap(); \
303 } \
304 wxSTATEMENT_MACRO_END
305
657a8a35
VZ
306 #define wxFAIL_MSG(msg) wxFAIL_COND_MSG("Assert failure", msg)
307 #define wxFAIL wxFAIL_MSG((const char*)NULL)
308#else // !wxDEBUG_LEVEL
309 #define wxTrap()
310
311 #define wxASSERT(cond)
312 #define wxASSERT_MSG(cond, msg)
313 #define wxFAIL
314 #define wxFAIL_MSG(msg)
315 #define wxFAIL_COND_MSG(cond, msg)
316#endif // wxDEBUG_LEVEL
317
318#if wxDEBUG_LEVEL >= 2
319 #define wxASSERT_LEVEL_2_MSG(cond, msg) wxASSERT_MSG(cond, msg)
320 #define wxASSERT_LEVEL_2(cond) wxASSERT(cond)
321#else // wxDEBUG_LEVEL < 2
b16f24dd
VZ
322 #define wxASSERT_LEVEL_2_MSG(cond, msg)
323 #define wxASSERT_LEVEL_2(cond)
657a8a35 324#endif
7ba4fbeb 325
975dc691
VZ
326// This is simply a wrapper for the standard abort() which is not available
327// under all platforms.
328//
329// It isn't really debug-related but there doesn't seem to be any better place
330// for it, so declare it here and define it in appbase.cpp, together with
331// wxTrap().
332extern void WXDLLIMPEXP_BASE wxAbort();
7ba4fbeb 333
657a8a35
VZ
334/*
335 wxCHECK macros always check their conditions, setting debug level to 0 only
336 makes them silent in case of failure, otherwise -- including at default
337 debug level 1 -- they call the assert handler if the condition is false
7ba4fbeb 338
657a8a35
VZ
339 They are supposed to be used only in invalid situation: for example, an
340 invalid parameter (e.g. a NULL pointer) is passed to a function. Instead of
341 dereferencing it and causing core dump the function might use
7ba4fbeb 342
657a8a35
VZ
343 wxCHECK_RET( p != NULL, "pointer can't be NULL" )
344*/
9d73af58 345
4c51a665 346// the generic macro: takes the condition to check, the statement to be executed
657a8a35 347// in case the condition is false and the message to pass to the assert handler
0d654944
SN
348#define wxCHECK2_MSG(cond, op, msg) \
349 if ( cond ) \
350 {} \
351 else \
352 { \
353 wxFAIL_COND_MSG(#cond, msg); \
354 op; \
355 } \
356 struct wxDummyCheckStruct /* just to force a semicolon */
7ba4fbeb 357
657a8a35
VZ
358// check which returns with the specified return code if the condition fails
359#define wxCHECK_MSG(cond, rc, msg) wxCHECK2_MSG(cond, return rc, msg)
360
361// check that expression is true, "return" if not (also FAILs in debug mode)
362#define wxCHECK(cond, rc) wxCHECK_MSG(cond, rc, (const char*)NULL)
363
364// check that expression is true, perform op if not
365#define wxCHECK2(cond, op) wxCHECK2_MSG(cond, op, (const char*)NULL)
366
993df040
VZ
367// special form of wxCHECK2: as wxCHECK, but for use in void functions
368//
369// NB: there is only one form (with msg parameter) and it's intentional:
370// there is no other way to tell the caller what exactly went wrong
371// from the void function (of course, the function shouldn't be void
372// to begin with...)
dfa0b52f 373#define wxCHECK_RET(cond, msg) wxCHECK2_MSG(cond, return, msg)
c801d85f 374
657a8a35 375
993df040
VZ
376// ----------------------------------------------------------------------------
377// Compile time asserts
378//
379// Unlike the normal assert and related macros above which are checked during
657a8a35 380// the program run-time the macros below will result in a compilation error if
993df040
VZ
381// the condition they check is false. This is usually used to check the
382// expressions containing sizeof()s which cannot be tested with the
383// preprocessor. If you can use the #if's, do use them as you can give a more
384// detailed error message then.
385// ----------------------------------------------------------------------------
8f5d9104
VZ
386
387/*
388 How this works (you don't have to understand it to be able to use the
389 macros): we rely on the fact that it is invalid to define a named bit field
390 in a struct of width 0. All the rest are just the hacks to minimize the
391 possibility of the compiler warnings when compiling this macro: in
392 particular, this is why we define a struct and not an object (which would
393 result in a warning about unused variable) and a named struct (otherwise we'd
394 get a warning about an unnamed struct not used to define an object!).
395 */
396
9bf41e06 397#define wxMAKE_UNIQUE_ASSERT_NAME wxMAKE_UNIQUE_NAME(wxAssert_)
8f5d9104
VZ
398
399/*
400 The second argument of this macro must be a valid C++ identifier and not a
401 string. I.e. you should use it like this:
402
403 wxCOMPILE_TIME_ASSERT( sizeof(int) >= 2, YourIntsAreTooSmall );
404
405 It may be used both within a function and in the global scope.
406*/
993df040 407#if defined(__WATCOMC__)
1c6f2414
WS
408 /* avoid "unused symbol" warning */
409 #define wxCOMPILE_TIME_ASSERT(expr, msg) \
410 class wxMAKE_UNIQUE_ASSERT_NAME { \
411 unsigned int msg: expr; \
871cc651 412 wxMAKE_UNIQUE_ASSERT_NAME() { wxUnusedVar(msg); } \
1c6f2414 413 }
7126436a
JJ
414#elif defined( __VMS )
415namespace wxdebug{
416
417// HP aCC cannot deal with missing names for template value parameters
418template <bool x> struct STATIC_ASSERTION_FAILURE;
419
420template <> struct STATIC_ASSERTION_FAILURE<true> { enum { value = 1 }; };
421
422// HP aCC cannot deal with missing names for template value parameters
423template<int x> struct static_assert_test{};
424
425}
426 #define WX_JOIN( X, Y ) X##Y
427 #define WX_STATIC_ASSERT_BOOL_CAST(x) (bool)(x)
428 #define wxCOMPILE_TIME_ASSERT(expr, msg) \
429 typedef ::wxdebug::static_assert_test<\
430 sizeof(::wxdebug::STATIC_ASSERTION_FAILURE< WX_STATIC_ASSERT_BOOL_CAST( expr ) >)>\
a4111501 431 WX_JOIN(wx_static_assert_typedef_, __LINE__)
1c6f2414
WS
432#else
433 #define wxCOMPILE_TIME_ASSERT(expr, msg) \
434 struct wxMAKE_UNIQUE_ASSERT_NAME { unsigned int msg: expr; }
435#endif
8f5d9104 436
871cc651
VZ
437/*
438 When using VC++ 6 with "Edit and Continue" on, the compiler completely
439 mishandles __LINE__ and so wxCOMPILE_TIME_ASSERT() doesn't work, provide a
440 way to make "unique" assert names by specifying a unique prefix explicitly
441 */
442#define wxMAKE_UNIQUE_ASSERT_NAME2(text) wxCONCAT(wxAssert_, text)
7bb688a8 443
17dc7ddd
WS
444#define wxCOMPILE_TIME_ASSERT2(expr, msg, text) \
445 struct wxMAKE_UNIQUE_ASSERT_NAME2(text) { unsigned int msg: expr; }
8de1759c 446
993df040 447// helpers for wxCOMPILE_TIME_ASSERT below, for private use only
8f5d9104
VZ
448#define wxMAKE_BITSIZE_MSG(type, size) type ## SmallerThan ## size ## Bits
449
993df040
VZ
450// a special case of compile time assert: check that the size of the given type
451// is at least the given number of bits
8f5d9104
VZ
452#define wxASSERT_MIN_BITSIZE(type, size) \
453 wxCOMPILE_TIME_ASSERT(sizeof(type) * CHAR_BIT >= size, \
454 wxMAKE_BITSIZE_MSG(type, size))
455
657a8a35 456
993df040
VZ
457// ----------------------------------------------------------------------------
458// other miscellaneous debugger-related functions
459// ----------------------------------------------------------------------------
a434b43f 460
c50a4038
VZ
461/*
462 Return true if we're running under debugger.
463
88ec47bb 464 Currently only really works under Win32 and just returns false elsewhere.
c50a4038 465 */
88ec47bb 466#if defined(__WIN32__)
993df040
VZ
467 extern bool WXDLLIMPEXP_BASE wxIsDebuggerRunning();
468#else // !Mac
469 inline bool wxIsDebuggerRunning() { return false; }
470#endif // Mac/!Mac
471
657a8a35
VZ
472// An assert helper used to avoid warning when testing constant expressions,
473// i.e. wxASSERT( sizeof(int) == 4 ) can generate a compiler warning about
474// expression being always true, but not using
475// wxASSERT( wxAssertIsEqual(sizeof(int), 4) )
476//
477// NB: this is made obsolete by wxCOMPILE_TIME_ASSERT() and should no
478// longer be used.
479extern bool WXDLLIMPEXP_BASE wxAssertIsEqual(int x, int y);
480
481// Use of wxFalse instead of false suppresses compiler warnings about testing
482// constant expression
483extern WXDLLIMPEXP_DATA_BASE(const bool) wxFalse;
484
485#define wxAssertFailure wxFalse
486
487// This is similar to WXUNUSED() and useful for parameters which are only used
488// in assertions.
489#if wxDEBUG_LEVEL
490 #define WXUNUSED_UNLESS_DEBUG(param) param
491#else
492 #define WXUNUSED_UNLESS_DEBUG(param) WXUNUSED(param)
493#endif
494
495
993df040 496#endif // _WX_DEBUG_H_