Updated PCI IDs to latest snapshot.
[tangerine.git] / workbench / classes / gadgets / texteditor / mcp / Debug.h
blob55314063288969fb9e699f3399e85397a680b4bf
1 /***************************************************************************
3 TextEditor.mcc - Textediting MUI Custom Class
4 Copyright (C) 1997-2000 Allan Odgaard
5 Copyright (C) 2005 by TextEditor.mcc Open Source Team
7 This library is free software; you can redistribute it and/or
8 modify it under the terms of the GNU Lesser General Public
9 License as published by the Free Software Foundation; either
10 version 2.1 of the License, or (at your option) any later version.
12 This library is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 Lesser General Public License for more details.
17 TextEditor class Support Site: http://www.sf.net/projects/texteditor-mcc
19 $Id$
21 ***************************************************************************/
23 #ifndef DEBUG_H
24 #define DEBUG_H
26 #ifdef __AROS__
27 #include <aros/debug.h>
28 #define KPutFmt vkprintf
29 #undef DEBUG
30 #endif
32 // first we make sure all previously defined symbols are undefined now so
33 // that no other debug system interferes with ours.
34 #undef ENTER
35 #undef LEAVE
36 #undef RETURN
37 #undef SHOWVALUE
38 #undef SHOWPOINTER
39 #undef SHOWSTRING
40 #undef SHOWMSG
41 #undef STARTCLOCK
42 #undef STOPCLOCK
43 #undef D
44 #undef E
45 #undef W
46 #undef ASSERT
48 #if defined(DEBUG)
50 #ifndef EXEC_TYPES_H
51 #include <exec/types.h>
52 #endif
54 #if defined(__amigaos4__)
55 #include <proto/exec.h>
56 #ifdef __USE_INLINE__
57 #ifdef DebugPrintF
58 #undef DebugPrintF
59 #endif
60 #endif
61 #ifndef kprintf
62 #define kprintf(format, args...) ((struct ExecIFace *)((*(struct ExecBase **)4)->MainInterface))->DebugPrintF(format, ## args)
63 #endif
64 #elif defined(__MORPHOS__)
65 #include <exec/rawfmt.h>
66 #include <proto/exec.h>
67 #define KPutFmt(format, args) VNewRawDoFmt(format, (APTR)RAWFMTFUNC_SERIAL, NULL, args)
68 void kprintf(const char *formatString,...);
69 #elif !defined(__AROS__)
70 void kprintf(const char *formatString,...);
71 #endif
73 // debug classes
74 #define DBC_CTRACE (1<<0) // call tracing (ENTER/LEAVE etc.)
75 #define DBC_REPORT (1<<1) // reports (SHOWVALUE/SHOWSTRING etc.)
76 #define DBC_ASSERT (1<<2) // asserts (ASSERT)
77 #define DBC_TIMEVAL (1<<3) // time evaluations (STARTCLOCK/STOPCLOCK)
78 #define DBC_DEBUG (1<<4) // debugging output D()
79 #define DBC_ERROR (1<<5) // error output E()
80 #define DBC_WARNING (1<<6) // warning output W()
81 #define DBC_ALL 0xffffffff
83 // debug flags
84 #define DBF_ALWAYS (1<<0)
85 #define DBF_STARTUP (1<<1) // for startup/shutdown events (YAM.c)
86 #define DBF_ALL 0xffffffff
88 void SetupDebug(void);
90 void _ENTER(unsigned long dclass, const char *file, int line, const char *function);
91 void _LEAVE(unsigned long dclass, const char *file, int line, const char *function);
92 void _RETURN(unsigned long dclass, const char *file, int line, const char *function, unsigned long result);
93 void _SHOWVALUE(unsigned long dclass, unsigned long dflags, unsigned long value, int size, const char *name, const char *file, int line);
94 void _SHOWPOINTER(unsigned long dclass, unsigned long dflags, const void *p, const char *name, const char *file, int line);
95 void _SHOWSTRING(unsigned long dclass, unsigned long dflags, const char *string, const char *name, const char *file, int line);
96 void _SHOWMSG(unsigned long dclass, unsigned long dflags, const char *msg, const char *file, int line);
97 void _DPRINTF(unsigned long dclass, unsigned long dflags, const char *file, int line, const char *format, ...);
99 // Core class information class messages
100 #define ENTER() _ENTER(DBC_CTRACE, __FILE__, __LINE__, __FUNCTION__)
101 #define LEAVE() _LEAVE(DBC_CTRACE, __FILE__, __LINE__, __FUNCTION__)
102 #define RETURN(r) _RETURN(DBC_CTRACE, __FILE__, __LINE__, __FUNCTION__, (long)r)
103 #define SHOWVALUE(f, v) _SHOWVALUE(DBC_REPORT, f, (long)v, sizeof(v), #v, __FILE__, __LINE__)
104 #define SHOWPOINTER(f, p) _SHOWPOINTER(DBC_REPORT, f, p, #p, __FILE__, __LINE__)
105 #define SHOWSTRING(f, s) _SHOWSTRING(DBC_REPORT, f, s, #s, __FILE__, __LINE__)
106 #define SHOWMSG(f, m) _SHOWMSG(DBC_REPORT, f, m, __FILE__, __LINE__)
107 #define D(f, s, vargs...) _DPRINTF(DBC_DEBUG, f, __FILE__, __LINE__, s, ## vargs)
108 #define E(f, s, vargs...) _DPRINTF(DBC_ERROR, f, __FILE__, __LINE__, s, ## vargs)
109 #define W(f, s, vargs...) _DPRINTF(DBC_WARNING, f, __FILE__, __LINE__, s, ## vargs)
110 #define ASSERT(expression) \
111 ((void) \
112 ((expression) ? 0 : \
114 _DPRINTF(DBC_ASSERT, \
115 DBF_ALWAYS, \
116 __FILE__, \
117 __LINE__, \
118 "failed assertion '%s'", \
119 #expression), \
120 abort(), \
126 #else // DEBUG
128 #define ENTER() ((void)0)
129 #define LEAVE() ((void)0)
130 #define RETURN(r) ((void)0)
131 #define SHOWVALUE(f, v) ((void)0)
132 #define SHOWPOINTER(f, p) ((void)0)
133 #define SHOWSTRING(f, s) ((void)0)
134 #define SHOWMSG(f, m) ((void)0)
135 #define D(f, s, vargs...) ((void)0)
136 #define E(f, s, vargs...) ((void)0)
137 #define W(f, s, vargs...) ((void)0)
138 #define ASSERT(expression) ((void)0)
140 #endif // DEBUG
142 #endif // DEBUG_H