#ifndef included_trace_h
#define included_trace_h
#include <xterm.h>
#if OPT_TRACE
extern void Trace ( const char *, ... ) GCC_PRINTFLIKE(1,2);
#undef TRACE
#define TRACE(p) Trace p
extern void TraceClose (void);
#undef TRACE_CLOSE
#define TRACE_CLOSE TraceClose
#if OPT_TRACE > 1
#define TRACE2(p) Trace p
#endif
extern char * visibleChars (const Char * , unsigned );
extern char * visibleIChar (IChar *, unsigned);
extern char * visibleIChars (IChar * , unsigned );
extern const char * visibleChrsetName(unsigned );
extern const char * visibleEventType (int);
extern const char * visibleNotifyDetail(int );
extern const char * visibleSelectionTarget(Display * , Atom );
extern const char * visibleXError (int );
extern void TraceArgv(const char * , char ** );
#undef TRACE_ARGV
#define TRACE_ARGV(tag,argv) TraceArgv(tag,argv)
extern const char *trace_who;
#undef TRACE_CHILD
#define TRACE_CHILD int tracing_child = (trace_who = "child") != 0; (void) tracing_child;
extern void TraceFocus(Widget, XEvent *);
#undef TRACE_FOCUS
#define TRACE_FOCUS(w,e) TraceFocus((Widget)w, (XEvent *)e)
extern void TraceSizeHints(XSizeHints *);
#undef TRACE_HINTS
#define TRACE_HINTS(hints) TraceSizeHints(hints)
extern void TraceIds(const char * , int );
#undef TRACE_IDS
#define TRACE_IDS TraceIds(__FILE__, __LINE__)
extern void TraceOptions(OptionHelp * , XrmOptionDescRec * , Cardinal );
#undef TRACE_OPTS
#define TRACE_OPTS(opts,ress,lens) TraceOptions(opts,ress,lens)
extern void TraceTranslations(const char *, Widget);
#undef TRACE_TRANS
#define TRACE_TRANS(name,w) TraceTranslations(name,w)
extern void TraceWMSizeHints(XtermWidget);
#undef TRACE_WM_HINTS
#define TRACE_WM_HINTS(w) TraceWMSizeHints(w)
extern void TraceXtermResources(void);
#undef TRACE_XRES
#define TRACE_XRES() TraceXtermResources()
extern int TraceResizeRequest(const char * , int , Widget , Dimension , Dimension , Dimension * , Dimension * );
#undef REQ_RESIZE
#define REQ_RESIZE(w, reqwide, reqhigh, gotwide, gothigh) \
TraceResizeRequest(__FILE__, __LINE__, w, \
(Dimension) (reqwide), (Dimension) (reqhigh), \
(gotwide), (gothigh))
#else
#define REQ_RESIZE(w, reqwide, reqhigh, gotwide, gothigh) \
XtMakeResizeRequest((Widget) (w), \
(Dimension) (reqwide), (Dimension) (reqhigh), \
(gotwide), (gothigh))
#endif
#if OPT_TRACE
#define init_Bres(name) \
TRACE(("init " #name " = %s\n", \
BtoS(wnew->name = request->name)))
#define init_Dres2(name,i) \
TRACE(("init " #name "[%d] = %f\n", i, \
wnew->name[i] = request->name[i]))
#define init_Ires(name) \
TRACE(("init " #name " = %d\n", \
wnew->name = request->name))
#define init_Sres(name) \
TRACE(("init " #name " = \"%s\"\n", \
(wnew->name = x_strtrim(request->name)) != NULL \
? wnew->name : "<null>"))
#define init_Sres2(name,i) \
TRACE(("init " #name "[%d] = \"%s\"\n", i, \
(wnew->name(i) = x_strtrim(request->name(i))) != NULL \
? wnew->name(i) : "<null>"))
#define init_Tres(offset) \
TRACE(("init screen.Tcolors[" #offset "] = %#lx\n", \
fill_Tres(wnew, request, offset)))
#else
#define init_Bres(name) wnew->name = request->name
#define init_Dres2(name,i) wnew->name[i] = request->name[i]
#define init_Ires(name) wnew->name = request->name
#define init_Sres(name) wnew->name = x_strtrim(request->name)
#define init_Sres2(name,i) wnew->name(i) = x_strtrim(request->name(i))
#define init_Tres(offset) fill_Tres(wnew, request, offset)
#endif
#endif