blob: 46b2c0833eff682b97c1ae8f51c5cf136903652a [file] [log] [blame]
Bram Moolenaar071d4272004-06-13 20:20:40 +00001/* vi:set ts=8 sts=8 sw=8:
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_DEBUG_ALL 0xffffffff
32
33#define NBDLEVEL(flags) (nb_debug != NULL && (nb_dlevel & (flags)))
34
35#define NBDEBUG_TRACE 1
36//#define NBDEBUG_SENSE 2
37
38typedef 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
45void nbdbg(char *, ...);
46void nbtrace(char *, ...);
47
48void nbdebug_wait __ARGS((u_int wait_flags, char *wait_var, u_int wait_secs));
49void nbdebug_log_init __ARGS((char *log_var, char *level_var));
50
51extern FILE *nb_debug;
52extern u_int nb_dlevel; /* nb_debug verbosity level */
53
54# else /* not NBDEBUG */
55
56#ifndef ASSERT
57# define ASSERT(c)
58#endif
59
60/*
61 * The following 2 stubs are needed because a macro cannot be used because of
62 * the variable number of arguments.
63 */
64
65void
66nbdbg(
67 char *fmt,
68 ...)
69{
70}
71
72
73void
74nbtrace(
75 char *fmt,
76 ...)
77{
78}
79
80#endif /* NBDEBUG */
81#endif /* NBDEBUG_H */