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