xref: /vim-8.2.3635/src/nbdebug.h (revision 952d9d82)
1edf3f97aSBram Moolenaar /* vi:set ts=8 sw=8 noet:
2071d4279SBram Moolenaar  *
3071d4279SBram Moolenaar  * VIM - Vi IMproved	by Bram Moolenaar
4071d4279SBram Moolenaar  *			Visual Workshop integration by Gordon Prieur
5071d4279SBram Moolenaar  *
6071d4279SBram Moolenaar  * Do ":help uganda"  in Vim to read copying and usage conditions.
7071d4279SBram Moolenaar  * Do ":help credits" in Vim to see a list of people who contributed.
8071d4279SBram Moolenaar  */
9071d4279SBram Moolenaar 
10071d4279SBram Moolenaar 
11071d4279SBram Moolenaar #ifndef NBDEBUG_H
12071d4279SBram Moolenaar #define NBDEBUG_H
13071d4279SBram Moolenaar 
14071d4279SBram Moolenaar #ifdef NBDEBUG
15071d4279SBram Moolenaar 
16071d4279SBram Moolenaar # ifndef ASSERT
17071d4279SBram Moolenaar #  define ASSERT(c) \
18071d4279SBram Moolenaar     if (!(c)) { \
19071d4279SBram Moolenaar 	fprintf(stderr, "Assertion failed: line %d, file %s\n", \
20071d4279SBram Moolenaar 		__LINE__, __FILE__); \
21071d4279SBram Moolenaar 	fflush(stderr); \
22071d4279SBram Moolenaar 	abort(); \
23071d4279SBram Moolenaar     }
24071d4279SBram Moolenaar # endif
25071d4279SBram Moolenaar 
268c8de839SBram Moolenaar # define nbdebug(a) nbdbg a
27071d4279SBram Moolenaar 
28071d4279SBram Moolenaar # define NB_TRACE		0x00000001
29071d4279SBram Moolenaar # define NB_TRACE_VERBOSE	0x00000002
30071d4279SBram Moolenaar # define NB_TRACE_COLONCMD	0x00000004
31009b2592SBram Moolenaar # define NB_PRINT		0x00000008
32071d4279SBram Moolenaar # define NB_DEBUG_ALL		0xffffffff
33071d4279SBram Moolenaar 
34071d4279SBram Moolenaar # define NBDLEVEL(flags)	(nb_debug != NULL && (nb_dlevel & (flags)))
35071d4279SBram Moolenaar 
36071d4279SBram Moolenaar # define NBDEBUG_TRACE	1
37071d4279SBram Moolenaar 
38071d4279SBram Moolenaar typedef enum {
399bf703d4SBram Moolenaar 		WT_ENV = 1,		// look for env var if set
409bf703d4SBram Moolenaar 		WT_WAIT,		// look for ~/.gvimwait if set
419bf703d4SBram Moolenaar 		WT_STOP			// look for ~/.gvimstop if set
42071d4279SBram Moolenaar } WtWait;
43071d4279SBram Moolenaar 
44071d4279SBram Moolenaar 
45*952d9d82SBram Moolenaar void		 nbdbg(char *, ...) ATTRIBUTE_FORMAT_PRINTF(1, 2);
46071d4279SBram Moolenaar 
47d99df423SBram Moolenaar void nbdebug_wait(u_int wait_flags, char *wait_var, u_int wait_secs);
48d99df423SBram Moolenaar void nbdebug_log_init(char *log_var, char *level_var);
49071d4279SBram Moolenaar 
50071d4279SBram Moolenaar extern FILE	*nb_debug;
519bf703d4SBram Moolenaar extern u_int	 nb_dlevel;		// nb_debug verbosity level
52071d4279SBram Moolenaar 
539bf703d4SBram Moolenaar #else		// not NBDEBUG
54071d4279SBram Moolenaar 
55071d4279SBram Moolenaar # ifndef ASSERT
56071d4279SBram Moolenaar #  define ASSERT(c)
57071d4279SBram Moolenaar # endif
58071d4279SBram Moolenaar 
59071d4279SBram Moolenaar /*
60009b2592SBram Moolenaar  * The following 3 stubs are needed because a macro cannot be used because of
61071d4279SBram Moolenaar  * the variable number of arguments.
62071d4279SBram Moolenaar  */
63071d4279SBram Moolenaar 
64071d4279SBram Moolenaar void
nbdbg(char * fmt,...)65071d4279SBram Moolenaar nbdbg(
66071d4279SBram Moolenaar 	char		*fmt,
67071d4279SBram Moolenaar 	...)
68071d4279SBram Moolenaar {
69071d4279SBram Moolenaar }
70071d4279SBram Moolenaar 
719bf703d4SBram Moolenaar #endif // NBDEBUG
729bf703d4SBram Moolenaar #endif // NBDEBUG_H
73