2018-03-29 14:22:05 -06:00
|
|
|
/* $XTermId: trace.h,v 1.81 2017/11/07 00:12:24 tom Exp $ */
|
2006-11-26 04:11:12 -07:00
|
|
|
|
2010-03-25 16:03:51 -06:00
|
|
|
/*
|
2017-07-15 13:20:51 -06:00
|
|
|
* Copyright 1997-2016,2017 by Thomas E. Dickey
|
2010-10-23 13:14:52 -06:00
|
|
|
*
|
2010-03-25 16:03:51 -06:00
|
|
|
* All Rights Reserved
|
2010-10-23 13:14:52 -06:00
|
|
|
*
|
2010-03-25 16:03:51 -06:00
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
* copy of this software and associated documentation files (the
|
|
|
|
* "Software"), to deal in the Software without restriction, including
|
|
|
|
* without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
* permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
* the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included
|
|
|
|
* in all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
|
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
|
|
* IN NO EVENT SHALL THE ABOVE LISTED COPYRIGHT HOLDER(S) BE LIABLE FOR ANY
|
|
|
|
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
|
|
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
|
|
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*
|
|
|
|
* Except as contained in this notice, the name(s) of the above copyright
|
|
|
|
* holders shall not be used in advertising or otherwise to promote the
|
|
|
|
* sale, use or other dealings in this Software without prior written
|
|
|
|
* authorization.
|
|
|
|
*/
|
2006-11-26 04:11:12 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Common/useful definitions for XTERM application
|
|
|
|
*/
|
|
|
|
#ifndef included_trace_h
|
|
|
|
#define included_trace_h
|
2011-08-28 11:40:55 -06:00
|
|
|
/* *INDENT-OFF* */
|
2006-11-26 04:11:12 -07:00
|
|
|
|
|
|
|
#include <xterm.h>
|
|
|
|
|
|
|
|
#if OPT_TRACE
|
|
|
|
|
2018-03-29 14:22:05 -06:00
|
|
|
#include <stdarg.h>
|
|
|
|
|
2016-08-07 15:27:36 -06:00
|
|
|
extern void Trace ( const char *, ... ) GCC_PRINTFLIKE(1,2);
|
2018-03-29 14:22:05 -06:00
|
|
|
extern void TraceVA ( const char *fmt, va_list ap );
|
2010-11-29 13:10:09 -07:00
|
|
|
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE(p) Trace p
|
|
|
|
|
2018-03-29 14:22:05 -06:00
|
|
|
#undef TRACE_VA
|
|
|
|
#define TRACE_VA(p) TraceVA p
|
|
|
|
|
2010-08-22 07:38:11 -06:00
|
|
|
extern void TraceClose (void);
|
|
|
|
|
|
|
|
#undef TRACE_CLOSE
|
|
|
|
#define TRACE_CLOSE TraceClose
|
|
|
|
|
2006-11-26 04:11:12 -07:00
|
|
|
#if OPT_TRACE > 1
|
|
|
|
#define TRACE2(p) Trace p
|
|
|
|
#endif
|
|
|
|
|
2016-08-07 15:27:36 -06:00
|
|
|
extern const char * visibleChars(const Char * /* buf */, unsigned /* len */);
|
|
|
|
extern const char * visibleIChars(const IChar * /* buf */, unsigned /* len */);
|
|
|
|
extern const char * visibleUChar(unsigned);
|
2014-01-02 08:14:50 -07:00
|
|
|
extern const char * visibleDblChrset(unsigned /* chrset */);
|
2007-06-15 13:29:55 -06:00
|
|
|
extern const char * visibleEventType (int);
|
2010-03-25 16:03:51 -06:00
|
|
|
extern const char * visibleNotifyDetail(int /* code */);
|
2013-01-04 09:40:18 -07:00
|
|
|
extern const char * visibleNotifyMode (int /* code */);
|
2014-01-02 08:14:50 -07:00
|
|
|
extern const char * visibleScsCode(int /* chrset */);
|
2009-04-04 09:10:44 -06:00
|
|
|
extern const char * visibleSelectionTarget(Display * /* d */, Atom /* a */);
|
2016-11-03 08:25:06 -06:00
|
|
|
extern const char * visibleTekparse (int);
|
|
|
|
extern const char * visibleVTparse (int);
|
2007-06-15 13:29:55 -06:00
|
|
|
extern const char * visibleXError (int /* code */);
|
2006-11-26 04:11:12 -07:00
|
|
|
|
2017-07-15 13:20:51 -06:00
|
|
|
extern const char * TraceAtomName(Display * /* d */, Atom /* a */);
|
|
|
|
|
2007-06-15 13:29:55 -06:00
|
|
|
extern void TraceArgv(const char * /* tag */, char ** /* argv */);
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE_ARGV
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE_ARGV(tag,argv) TraceArgv(tag,argv)
|
|
|
|
|
2009-10-31 08:11:57 -06:00
|
|
|
extern const char *trace_who;
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE_CHILD
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE_CHILD int tracing_child = (trace_who = "child") != 0; (void) tracing_child;
|
|
|
|
|
2010-03-25 16:03:51 -06:00
|
|
|
extern void TraceFocus(Widget, XEvent *);
|
|
|
|
#undef TRACE_FOCUS
|
|
|
|
#define TRACE_FOCUS(w,e) TraceFocus((Widget)w, (XEvent *)e)
|
|
|
|
|
2006-11-26 04:11:12 -07:00
|
|
|
extern void TraceSizeHints(XSizeHints *);
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE_HINTS
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE_HINTS(hints) TraceSizeHints(hints)
|
|
|
|
|
2008-08-25 12:05:56 -06:00
|
|
|
extern void TraceIds(const char * /* fname */, int /* lnum */);
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE_IDS
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE_IDS TraceIds(__FILE__, __LINE__)
|
|
|
|
|
2011-09-17 05:51:57 -06:00
|
|
|
extern void TraceTime(const char * /* fname */, int /* lnum */);
|
|
|
|
#undef TRACE_TIME
|
|
|
|
#define TRACE_TIME TraceTime(__FILE__, __LINE__)
|
|
|
|
|
2008-08-25 12:05:56 -06:00
|
|
|
extern void TraceOptions(OptionHelp * /* options */, XrmOptionDescRec * /* resources */, Cardinal /* count */);
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE_OPTS
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE_OPTS(opts,ress,lens) TraceOptions(opts,ress,lens)
|
|
|
|
|
|
|
|
extern void TraceTranslations(const char *, Widget);
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE_TRANS
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE_TRANS(name,w) TraceTranslations(name,w)
|
|
|
|
|
2011-08-28 11:40:55 -06:00
|
|
|
extern void TraceWindowAttributes(XWindowAttributes *);
|
|
|
|
#undef TRACE_WIN_ATTRS
|
|
|
|
#define TRACE_WIN_ATTRS(a) TraceWindowAttributes(a)
|
|
|
|
|
2006-11-26 04:11:12 -07:00
|
|
|
extern void TraceWMSizeHints(XtermWidget);
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE_WM_HINTS
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE_WM_HINTS(w) TraceWMSizeHints(w)
|
|
|
|
|
|
|
|
extern void TraceXtermResources(void);
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef TRACE_XRES
|
2006-11-26 04:11:12 -07:00
|
|
|
#define TRACE_XRES() TraceXtermResources()
|
|
|
|
|
2011-08-28 11:40:55 -06:00
|
|
|
extern XtGeometryResult TraceResizeRequest(const char * /* fn */, int /* ln */, Widget /* w */, unsigned /* reqwide */, unsigned /* reqhigh */, Dimension * /* gotwide */, Dimension * /* gothigh */);
|
2009-04-04 09:10:44 -06:00
|
|
|
#undef REQ_RESIZE
|
2008-08-25 12:05:56 -06:00
|
|
|
#define REQ_RESIZE(w, reqwide, reqhigh, gotwide, gothigh) \
|
2010-05-08 06:20:46 -06:00
|
|
|
TraceResizeRequest(__FILE__, __LINE__, w, \
|
2011-08-18 13:47:42 -06:00
|
|
|
(reqwide), (reqhigh), \
|
2010-05-08 06:20:46 -06:00
|
|
|
(gotwide), (gothigh))
|
2008-08-25 12:05:56 -06:00
|
|
|
|
2013-03-09 07:45:38 -07:00
|
|
|
extern const char * ModifierName(unsigned /* modifier */);
|
|
|
|
#define FMT_MODIFIER_NAMES "%s%s%s%s%s%s%s%s"
|
|
|
|
#define ARG_MODIFIER_NAMES(state) \
|
|
|
|
ModifierName(state & ShiftMask), \
|
|
|
|
ModifierName(state & LockMask), \
|
|
|
|
ModifierName(state & ControlMask), \
|
|
|
|
ModifierName(state & Mod1Mask), \
|
|
|
|
ModifierName(state & Mod2Mask), \
|
|
|
|
ModifierName(state & Mod3Mask), \
|
|
|
|
ModifierName(state & Mod4Mask), \
|
|
|
|
ModifierName(state & Mod5Mask)
|
|
|
|
|
2008-08-25 12:05:56 -06:00
|
|
|
#else
|
|
|
|
|
|
|
|
#define REQ_RESIZE(w, reqwide, reqhigh, gotwide, gothigh) \
|
|
|
|
XtMakeResizeRequest((Widget) (w), \
|
|
|
|
(Dimension) (reqwide), (Dimension) (reqhigh), \
|
|
|
|
(gotwide), (gothigh))
|
|
|
|
|
2006-11-26 04:11:12 -07:00
|
|
|
#endif
|
|
|
|
|
2012-06-07 14:20:23 -06:00
|
|
|
extern void TraceScreen(XtermWidget /* xw */, int /* whichBuf */);
|
|
|
|
|
2010-10-23 13:14:52 -06:00
|
|
|
/*
|
|
|
|
* The whole wnew->screen struct is zeroed in VTInitialize. Use these macros
|
|
|
|
* where applicable for copying the pieces from the request widget into the
|
|
|
|
* new widget. We do not have to use them for wnew->misc, but the associated
|
|
|
|
* traces are very useful for debugging.
|
|
|
|
*/
|
|
|
|
#if OPT_TRACE
|
|
|
|
#define init_Bres(name) \
|
|
|
|
TRACE(("init " #name " = %s\n", \
|
|
|
|
BtoS(wnew->name = request->name)))
|
2011-09-17 05:51:57 -06:00
|
|
|
#define init_Dres(name) \
|
|
|
|
TRACE(("init " #name " = %f\n", \
|
|
|
|
wnew->name = request->name))
|
2010-10-23 13:14:52 -06:00
|
|
|
#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))
|
2015-09-05 08:11:45 -06:00
|
|
|
#define init_Mres(name) \
|
|
|
|
TRACE(("init " #name " = %s\n", \
|
|
|
|
MtoS(wnew->name = request->name)))
|
2010-10-23 13:14:52 -06:00
|
|
|
#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
|
2011-09-17 05:51:57 -06:00
|
|
|
#define init_Dres(name) wnew->name = request->name
|
2010-10-23 13:14:52 -06:00
|
|
|
#define init_Dres2(name,i) wnew->name[i] = request->name[i]
|
|
|
|
#define init_Ires(name) wnew->name = request->name
|
2015-09-05 08:11:45 -06:00
|
|
|
#define init_Mres(name) wnew->name = request->name
|
2010-10-23 13:14:52 -06:00
|
|
|
#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
|
|
|
|
|
2011-08-28 11:40:55 -06:00
|
|
|
/* *INDENT-ON* */
|
2010-10-23 13:14:52 -06:00
|
|
|
|
2013-01-04 09:40:18 -07:00
|
|
|
#endif /* included_trace_h */
|