xref: /vim-8.2.3635/src/nbdebug.h (revision 2d2970ea)
1 /* vi:set ts=8 sw=8 noet:
2  *
3  * VIM - Vi IMproved	by Bram Moolenaar
4  *			Visual Workshop integration by Gordon Prieur
5  *
6  * Do ":help uganda"  in Vim to read copying and usage conditions.
7  * Do ":help credits" in Vim to see a list of people who contributed.
8  */
9 
10 
11 #ifndef NBDEBUG_H
12 #define NBDEBUG_H
13 
14 #ifdef NBDEBUG
15 
16 # ifndef ASSERT
17 #  define ASSERT(c) \
18     if (!(c)) { \
19 	fprintf(stderr, "Assertion failed: line %d, file %s\n", \
20 		__LINE__, __FILE__); \
21 	fflush(stderr); \
22 	abort(); \
23     }
24 # endif
25 
26 # define nbdebug(a) nbdbg a
27 
28 # define NB_TRACE		0x00000001
29 # define NB_TRACE_VERBOSE	0x00000002
30 # define NB_TRACE_COLONCMD	0x00000004
31 # define NB_PRINT		0x00000008
32 # define NB_DEBUG_ALL		0xffffffff
33 
34 # define NBDLEVEL(flags)	(nb_debug != NULL && (nb_dlevel & (flags)))
35 
36 # define NBDEBUG_TRACE	1
37 
38 typedef enum {
39 		WT_ENV = 1,		// look for env var if set
40 		WT_WAIT,		// look for ~/.gvimwait if set
41 		WT_STOP			// look for ~/.gvimstop if set
42 } WtWait;
43 
44 
45 void		 nbdbg(char *, ...)
46 # ifdef USE_PRINTF_FORMAT_ATTRIBUTE
47    __attribute__((format(printf, 1, 2)))
48 # endif
49 ;
50 
51 void nbdebug_wait(u_int wait_flags, char *wait_var, u_int wait_secs);
52 void nbdebug_log_init(char *log_var, char *level_var);
53 
54 extern FILE	*nb_debug;
55 extern u_int	 nb_dlevel;		// nb_debug verbosity level
56 
57 #else		// not NBDEBUG
58 
59 # ifndef ASSERT
60 #  define ASSERT(c)
61 # endif
62 
63 /*
64  * The following 3 stubs are needed because a macro cannot be used because of
65  * the variable number of arguments.
66  */
67 
68 void
69 nbdbg(
70 	char		*fmt,
71 	...)
72 {
73 }
74 
75 #endif // NBDEBUG
76 #endif // NBDEBUG_H
77