1 karl 1.6 //%2006////////////////////////////////////////////////////////////////////////
|
2 jim.wunderlich 1.1 //
3 // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development
4 // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.
5 // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;
6 // IBM Corp.; EMC Corporation, The Open Group.
7 // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;
8 // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.
9 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
10 // EMC Corporation; VERITAS Software Corporation; The Open Group.
|
11 karl 1.6 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
12 // EMC Corporation; Symantec Corporation; The Open Group.
|
13 jim.wunderlich 1.1 //
14 // Permission is hereby granted, free of charge, to any person obtaining a copy
15 // of this software and associated documentation files (the "Software"), to
16 // deal in the Software without restriction, including without limitation the
17 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
18 // sell copies of the Software, and to permit persons to whom the Software is
19 // furnished to do so, subject to the following conditions:
20 //
21 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
22 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
23 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
24 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
25 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
26 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
27 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29 //
30 //==============================================================================
31 //
32 //%/////////////////////////////////////////////////////////////////////////////
33 #ifndef Pegasus_Assert_h
34 jim.wunderlich 1.1 #define Pegasus_Assert_h
35
|
36 thilo.boehm 1.10 #ifdef PEGASUS_OS_ZOS
37 // zOS specific implementation of assert macros.
38 # include <Pegasus/Common/PegasusAssertZOS.h>
|
39 kumpf 1.7
|
40 thilo.boehm 1.10 #else
|
41 kumpf 1.7 // NOTE:
|
42 jim.wunderlich 1.2 //
|
43 thilo.boehm 1.10 // This is the common implementation for the assert macros.
44 // If platform specific implementation are needed they have to
45 // be placed in a platform specific include file and included before.
46 //
|
47 kumpf 1.7 // All built and tested OK with <assert.h>
|
48 jim.wunderlich 1.2 // but <cassert> is more appropriate for c++ files
|
49 kumpf 1.7 // however if this should be a problem for any c fileswithin the tree
50 // it is possible to revert back to assert.h
|
51 jim.wunderlich 1.2 // J Wunderlich 11/21/2005
52 //
|
53 jim.wunderlich 1.4
54 #if (__cplusplus)
|
55 jim.wunderlich 1.2 #include <cassert>
|
56 jim.wunderlich 1.4 #else
57 #include <assert.h>
58 #endif
|
59 jim.wunderlich 1.1
|
60 jim.wunderlich 1.3 /** define PEGASUS_ASSERT assertion statement. This statement tests the
61 condition defined by the parameters and if not True executes an
62
|
63 kumpf 1.7 It only generates code if NDEBUG is not defined.
|
64 jim.wunderlich 1.3 See also the man page for assert().
65
|
66 kumpf 1.7 NOTE: if NDEBUG is set then the assert() macro will generate no code,
67 and hence do nothing at all.
|
68 jim.wunderlich 1.3
69 <pre>
70 assert()
71 </pre>
72
73 defining the file, line and condition that was tested.
74 */
75
|
76 marek 1.9 #define PEGASUS_ASSERT(COND) assert(COND)
77
|
78 jim.wunderlich 1.1
79 /* define PEGASUS_DEBUG_ASSERT() assertion statement. This statement tests the
|
80 kumpf 1.7 condition defined by the parameters and if not True executes an assert.
|
81 jim.wunderlich 1.1 It only generates code if PEGASUS_DEBUG is defined and NDEBUG is not
|
82 kumpf 1.7 defined.
|
83 jim.wunderlich 1.1 See also the man page for assert().
84
|
85 kumpf 1.7 NOTE: if NDEBUG is set then the assert() macro will generate no code,
86 and hence do nothing at all.
|
87 jim.wunderlich 1.1
88 */
89
90 #ifdef PEGASUS_DEBUG
|
91 marek 1.9 # define PEGASUS_DEBUG_ASSERT(COND) assert(COND)
|
92 jim.wunderlich 1.1 #else
|
93 kumpf 1.7 # define PEGASUS_DEBUG_ASSERT(COND)
|
94 jim.wunderlich 1.1 #endif
95
96
|
97 kumpf 1.7 #define PEGASUS_TEST_ASSERT(COND) \
98 do \
99 { \
100 if (!(COND)) \
101 { \
102 printf("PEGASUS_TEST_ASSERT failed in file %s at line %d\n", \
103 __FILE__, __LINE__); \
104 abort(); \
105 } \
106 } while (0)
|
107 jim.wunderlich 1.2
|
108 thilo.boehm 1.10 # endif /* Common Pegasus Assert implementation */
|
109 jim.wunderlich 1.1 #endif /* Pegasus_Assert_h */
|