1 /***************************************************************************
3 NBalance.mcc - New Balance MUI Custom Class
4 Copyright (C) 2008-2013 by NList Open Source Team
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 NList classes Support Site: http://www.sf.net/projects/nlist-classes
20 ***************************************************************************/
25 // first we make sure all previously defined symbols are undefined now so
26 // that no other debug system interferes with ours.
46 #include <exec/types.h>
49 #if defined(__amigaos4__)
50 #include <proto/exec.h>
57 #define kprintf(format, args...) ((struct ExecIFace *)((*(struct ExecBase **)4)->MainInterface))->DebugPrintF(format, ## args)
59 #elif defined(__MORPHOS__)
60 #include <exec/rawfmt.h>
61 #include <proto/exec.h>
62 #define KPutFmt(format, args) VNewRawDoFmt(format, (APTR)RAWFMTFUNC_SERIAL, NULL, args)
63 void kprintf(const char *formatString
,...);
65 void kprintf(const char *formatString
,...);
69 #define DBC_CTRACE (1<<0) // call tracing (ENTER/LEAVE etc.)
70 #define DBC_REPORT (1<<1) // reports (SHOWVALUE/SHOWSTRING etc.)
71 #define DBC_ASSERT (1<<2) // asserts (ASSERT)
72 #define DBC_TIMEVAL (1<<3) // time evaluations (STARTCLOCK/STOPCLOCK)
73 #define DBC_DEBUG (1<<4) // debugging output D()
74 #define DBC_ERROR (1<<5) // error output E()
75 #define DBC_WARNING (1<<6) // warning output W()
76 #define DBC_ALL 0xffffffff
79 #define DBF_ALWAYS (1<<0)
80 #define DBF_STARTUP (1<<1) // for startup/shutdown events
81 #define DBF_INPUT (1<<2)
82 #define DBF_GUI (1<<3)
83 #define DBF_ALL 0xffffffff
85 void SetupDebug(void);
86 void CleanupDebug(void);
88 void _ENTER(unsigned long dclass
, const char *file
, int line
, const char *function
);
89 void _LEAVE(unsigned long dclass
, const char *file
, int line
, const char *function
);
90 void _RETURN(unsigned long dclass
, const char *file
, int line
, const char *function
, unsigned long result
);
91 void _SHOWVALUE(unsigned long dclass
, unsigned long dflags
, unsigned long value
, int size
, const char *name
, const char *file
, int line
);
92 void _SHOWPOINTER(unsigned long dclass
, unsigned long dflags
, const void *p
, const char *name
, const char *file
, int line
);
93 void _SHOWSTRING(unsigned long dclass
, unsigned long dflags
, const char *string
, const char *name
, const char *file
, int line
);
94 void _SHOWMSG(unsigned long dclass
, unsigned long dflags
, const char *msg
, const char *file
, int line
);
95 void _DPRINTF(unsigned long dclass
, unsigned long dflags
, const char *file
, int line
, const char *format
, ...);
97 // Core class information class messages
98 #define ENTER() _ENTER(DBC_CTRACE, __FILE__, __LINE__, __FUNCTION__)
99 #define LEAVE() _LEAVE(DBC_CTRACE, __FILE__, __LINE__, __FUNCTION__)
100 #define RETURN(r) _RETURN(DBC_CTRACE, __FILE__, __LINE__, __FUNCTION__, (long)r)
101 #define SHOWVALUE(f, v) _SHOWVALUE(DBC_REPORT, f, (long)v, sizeof(v), #v, __FILE__, __LINE__)
102 #define SHOWPOINTER(f, p) _SHOWPOINTER(DBC_REPORT, f, p, #p, __FILE__, __LINE__)
103 #define SHOWSTRING(f, s) _SHOWSTRING(DBC_REPORT, f, s, #s, __FILE__, __LINE__)
104 #define SHOWMSG(f, m) _SHOWMSG(DBC_REPORT, f, m, __FILE__, __LINE__)
105 #define D(f, s, vargs...) _DPRINTF(DBC_DEBUG, f, __FILE__, __LINE__, s, ## vargs)
106 #define E(f, s, vargs...) _DPRINTF(DBC_ERROR, f, __FILE__, __LINE__, s, ## vargs)
107 #define W(f, s, vargs...) _DPRINTF(DBC_WARNING, f, __FILE__, __LINE__, s, ## vargs)
108 #define ASSERT(expression) \
110 ((expression) ? 0 : \
112 _DPRINTF(DBC_ASSERT, \
116 "failed assertion '%s'", \
118 assert(#expression), \
126 #define ENTER() ((void)0)
127 #define LEAVE() ((void)0)
128 #define RETURN(r) ((void)0)
129 #define SHOWVALUE(f, v) ((void)0)
130 #define SHOWPOINTER(f, p) ((void)0)
131 #define SHOWSTRING(f, s) ((void)0)
132 #define SHOWMSG(f, m) ((void)0)
133 #define D(f, s, vargs...) ((void)0)
134 #define E(f, s, vargs...) ((void)0)
135 #define W(f, s, vargs...) ((void)0)
136 #define ASSERT(expression) ((void)0)