2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
2008-03-08 14:43:31 +00:00
|
|
|
// Name: debug.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of global functions
|
2008-03-08 14:43:31 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
/** @ingroup group_funcmacro_debug */
|
|
|
|
//@{
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-15 03:14:51 +00:00
|
|
|
Assert macro. An error message will be generated if the condition is @false in
|
|
|
|
debug mode, but nothing will be done in the release build.
|
2008-10-14 19:40:39 +00:00
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
Please note that the condition in wxASSERT() should have no side effects
|
|
|
|
because it will not be executed in release mode at all.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (in debug builds) logical errors done
|
|
|
|
by the programmer.
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@see wxASSERT_MSG(), wxCOMPILE_TIME_ASSERT()
|
2008-03-08 13:52:38 +00:00
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
#define wxASSERT( condition )
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-10-04 20:49:51 +00:00
|
|
|
This macro results in a @ref wxCOMPILE_TIME_ASSERT "compile time assertion failure"
|
|
|
|
if the size of the given @c type is less than @c size bits.
|
2008-03-15 03:14:51 +00:00
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (in debug builds) logical errors done
|
|
|
|
by the programmer.
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
You may use it like this, for example:
|
2008-03-09 12:33:59 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@code
|
|
|
|
// we rely on the int being able to hold values up to 2^32
|
2008-03-15 03:14:51 +00:00
|
|
|
wxASSERT_MIN_BITSIZE(int, 32);
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
// can't work with the platforms using UTF-8 for wchar_t
|
|
|
|
wxASSERT_MIN_BITSIZE(wchar_t, 16);
|
2008-03-08 13:52:38 +00:00
|
|
|
@endcode
|
2008-03-15 03:14:51 +00:00
|
|
|
|
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
#define wxASSERT_MIN_BITSIZE( type, size )
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-10-04 20:49:51 +00:00
|
|
|
Assert macro with message.
|
|
|
|
An error message will be generated if the condition is @false.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (in debug builds) logical errors done
|
|
|
|
by the programmer.
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxASSERT(), wxCOMPILE_TIME_ASSERT()
|
2008-03-08 13:52:38 +00:00
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
#define wxASSERT_MSG( condition, message )
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-15 03:14:51 +00:00
|
|
|
Checks that the condition is @true, returns with the given return value if
|
2008-10-04 20:49:51 +00:00
|
|
|
not (stops execution in debug mode). This check is done even in release mode.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (both in debug and release builds) logical
|
|
|
|
errors done by the programmer.
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
#define wxCHECK( condition, retValue )
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-15 03:14:51 +00:00
|
|
|
Checks that the condition is @true, returns with the given return value if
|
2008-10-04 20:49:51 +00:00
|
|
|
not (stops execution in debug mode). This check is done even in release mode.
|
2008-03-15 03:14:51 +00:00
|
|
|
|
|
|
|
This macro may be only used in non-void functions, see also wxCHECK_RET().
|
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (both in debug and release builds) logical
|
|
|
|
errors done by the programmer.
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
#define wxCHECK_MSG( condition, retValue, message )
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-15 03:14:51 +00:00
|
|
|
Checks that the condition is @true, and returns if not (stops execution
|
|
|
|
with the given error message in debug mode). This check is done even in
|
|
|
|
release mode.
|
|
|
|
|
|
|
|
This macro should be used in void functions instead of wxCHECK_MSG().
|
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (both in debug and release builds) logical
|
|
|
|
errors done by the programmer.
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
#define wxCHECK_RET( condition, message )
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-15 03:14:51 +00:00
|
|
|
Checks that the condition is @true, and if not, it will wxFAIL() and
|
|
|
|
execute the given @c operation if it is not. This is a generalisation of
|
|
|
|
wxCHECK() and may be used when something else than just returning from the
|
|
|
|
function must be done when the @c condition is @false. This check is done
|
|
|
|
even in release mode.
|
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (both in debug and release builds) logical
|
|
|
|
errors done by the programmer.
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
#define wxCHECK2(condition, operation)
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-15 03:14:51 +00:00
|
|
|
This is the same as wxCHECK2(), but wxFAIL_MSG() with the specified
|
|
|
|
@c message is called instead of wxFAIL() if the @c condition is @false.
|
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (both in debug and release builds) logical
|
|
|
|
errors done by the programmer.
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
#define wxCHECK2_MSG( condition, operation, message )
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-15 03:14:51 +00:00
|
|
|
Using wxCOMPILE_TIME_ASSERT() results in a compilation error if the
|
|
|
|
specified @c condition is @false. The compiler error message should include
|
|
|
|
the @c message identifier - please note that it must be a valid C++
|
|
|
|
identifier and not a string unlike in the other cases.
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This macro is mostly useful for testing the expressions involving the
|
|
|
|
@c sizeof operator as they can't be tested by the preprocessor but it is
|
|
|
|
sometimes desirable to test them at the compile time.
|
2008-03-15 03:14:51 +00:00
|
|
|
|
|
|
|
Note that this macro internally declares a struct whose name it tries to
|
|
|
|
make unique by using the @c __LINE__ in it but it may still not work if you
|
2008-03-08 13:52:38 +00:00
|
|
|
use it on the same line in two different source files. In this case you may
|
|
|
|
either change the line in which either of them appears on or use the
|
2008-03-10 15:24:38 +00:00
|
|
|
wxCOMPILE_TIME_ASSERT2() macro.
|
2008-03-15 03:14:51 +00:00
|
|
|
|
|
|
|
Also note that Microsoft Visual C++ has a bug which results in compiler
|
|
|
|
errors if you use this macro with 'Program Database For Edit And Continue'
|
|
|
|
(@c /ZI) option, so you shouldn't use it ('Program Database' (@c /Zi) is ok
|
|
|
|
though) for the code making use of this macro.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch misconfigurations at compile-time.
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxASSERT_MSG(), wxASSERT_MIN_BITSIZE()
|
2008-03-15 03:14:51 +00:00
|
|
|
|
|
|
|
@header{wx/debug.h}
|
|
|
|
*/
|
|
|
|
#define wxCOMPILE_TIME_ASSERT( condition, message )
|
|
|
|
|
|
|
|
/**
|
|
|
|
This macro is identical to wxCOMPILE_TIME_ASSERT() except that it allows
|
|
|
|
you to specify a unique @c name for the struct internally defined by this
|
|
|
|
macro to avoid getting the compilation errors described for
|
|
|
|
wxCOMPILE_TIME_ASSERT().
|
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch misconfigurations at compile-time.
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@header{wx/debug.h}
|
|
|
|
*/
|
|
|
|
#define wxCOMPILE_TIME_ASSERT2(condition, message, name)
|
|
|
|
|
|
|
|
/**
|
2008-10-14 19:40:39 +00:00
|
|
|
Will always generate an assert error if this code is reached (in debug mode).
|
|
|
|
Note that you don't have to (and cannot) use brackets when invoking this
|
|
|
|
macro:
|
|
|
|
|
|
|
|
@code
|
|
|
|
if (...some condition...) {
|
|
|
|
wxFAIL;
|
|
|
|
}
|
|
|
|
@endcode
|
|
|
|
|
|
|
|
This macro should be used to catch (in debug builds) logical errors done
|
|
|
|
by the programmer.
|
2008-03-15 03:14:51 +00:00
|
|
|
|
|
|
|
@see wxFAIL_MSG()
|
|
|
|
|
|
|
|
@header{wx/debug.h}
|
|
|
|
*/
|
2008-10-14 19:40:39 +00:00
|
|
|
#define wxFAIL
|
2008-03-15 03:14:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Will always generate an assert error with specified message if this code is
|
|
|
|
reached (in debug mode).
|
|
|
|
|
|
|
|
This macro is useful for marking unreachable" code areas, for example it
|
|
|
|
may be used in the "default:" branch of a switch statement if all possible
|
|
|
|
cases are processed above.
|
|
|
|
|
2008-10-14 19:40:39 +00:00
|
|
|
This macro should be used to catch (in debug builds) logical errors done
|
|
|
|
by the programmer.
|
|
|
|
|
2008-03-15 03:14:51 +00:00
|
|
|
@see wxFAIL()
|
|
|
|
|
|
|
|
@header{wx/debug.h}
|
|
|
|
*/
|
|
|
|
#define wxFAIL_MSG( message )
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the program is running under debugger, @false otherwise.
|
|
|
|
|
|
|
|
Please note that this function is currently only implemented for Win32 and
|
|
|
|
Mac builds using CodeWarrior and always returns @false elsewhere.
|
|
|
|
|
|
|
|
@header{wx/debug.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-15 03:14:51 +00:00
|
|
|
bool wxIsDebuggerRunning();
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function is called whenever one of debugging macros fails (i.e.
|
|
|
|
condition is @false in an assertion). It is only defined in the debug mode,
|
|
|
|
in release builds the wxCHECK() failures don't result in anything.
|
|
|
|
|
|
|
|
To override the default behaviour in the debug builds which is to show the
|
|
|
|
user a dialog asking whether he wants to abort the program, continue or
|
|
|
|
continue ignoring any subsequent assert failures, you may override
|
|
|
|
wxApp::OnAssertFailure() which is called by this function if the global
|
|
|
|
application object exists.
|
|
|
|
|
|
|
|
@header{wx/debug.h}
|
|
|
|
*/
|
|
|
|
void wxOnAssert( const char* fileName,
|
|
|
|
int lineNumber,
|
|
|
|
const char* function,
|
|
|
|
const char* condition,
|
|
|
|
const char* message = NULL );
|
|
|
|
|
|
|
|
/**
|
|
|
|
In debug mode (when @c __WXDEBUG__ is defined) this function generates a
|
|
|
|
debugger exception meaning that the control is passed to the debugger if
|
|
|
|
one is attached to the process. Otherwise the program just terminates
|
|
|
|
abnormally. In release mode this function does nothing.
|
|
|
|
|
|
|
|
@header{wx/debug.h}
|
|
|
|
*/
|
|
|
|
void wxTrap();
|
|
|
|
|
|
|
|
//@}
|
2008-03-08 13:52:38 +00:00
|
|
|
|
2008-03-23 18:24:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
/** @ingroup group_funcmacro_misc */
|
|
|
|
//@{
|
|
|
|
|
|
|
|
/**
|
|
|
|
This macro expands to the name of the current function if the compiler
|
|
|
|
supports any of @c __FUNCTION__, @c __func__ or equivalent variables or
|
|
|
|
macros or to @NULL if none of them is available.
|
|
|
|
|
|
|
|
@header{wx/debug.h}
|
|
|
|
*/
|
|
|
|
#define __WXFUNCTION__
|
|
|
|
|
|
|
|
//@}
|
|
|
|
|