1 | /* Debugging macros and interface.
|
---|
2 | Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008,
|
---|
3 | 2009, 2010 Free Software Foundation, Inc.
|
---|
4 | This file is part of GNU Make.
|
---|
5 |
|
---|
6 | GNU Make is free software; you can redistribute it and/or modify it under the
|
---|
7 | terms of the GNU General Public License as published by the Free Software
|
---|
8 | Foundation; either version 3 of the License, or (at your option) any later
|
---|
9 | version.
|
---|
10 |
|
---|
11 | GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
|
---|
12 | WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
---|
13 | A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
---|
14 |
|
---|
15 | You should have received a copy of the GNU General Public License along with
|
---|
16 | this program. If not, see <http://www.gnu.org/licenses/>. */
|
---|
17 |
|
---|
18 | #define DB_NONE (0x000)
|
---|
19 | #define DB_BASIC (0x001)
|
---|
20 | #define DB_VERBOSE (0x002)
|
---|
21 | #define DB_JOBS (0x004)
|
---|
22 | #define DB_IMPLICIT (0x008)
|
---|
23 | #define DB_MAKEFILES (0x100)
|
---|
24 | #ifdef KMK
|
---|
25 | # define DB_KMK (0x800)
|
---|
26 | #endif
|
---|
27 |
|
---|
28 | #define DB_ALL (0xfff)
|
---|
29 |
|
---|
30 | extern int db_level;
|
---|
31 |
|
---|
32 | #ifdef KMK
|
---|
33 |
|
---|
34 | /* Some extended info for -j and .NOTPARALLEL tracking. */
|
---|
35 | extern unsigned int makelevel;
|
---|
36 | extern unsigned int job_slots;
|
---|
37 | extern unsigned int job_slots_used;
|
---|
38 |
|
---|
39 | #define DB_HDR() do { printf ("[%u:%u/%u]", makelevel, job_slots_used, job_slots); } while (0)
|
---|
40 |
|
---|
41 | #define ISDB(_l) ((_l)&db_level)
|
---|
42 |
|
---|
43 | #define DBS(_l,_x) do{ if(ISDB(_l)) {DB_HDR(); \
|
---|
44 | print_spaces (depth); \
|
---|
45 | printf _x; fflush (stdout);} }while(0)
|
---|
46 |
|
---|
47 | #define DBF(_l,_x) do{ if(ISDB(_l)) {DB_HDR(); \
|
---|
48 | print_spaces (depth); \
|
---|
49 | printf (_x, file->name); \
|
---|
50 | fflush (stdout);} }while(0)
|
---|
51 |
|
---|
52 | #define DB(_l,_x) do{ if(ISDB(_l)) {DB_HDR(); printf _x; fflush (stdout);} }while(0)
|
---|
53 |
|
---|
54 | #else /* !KMK */
|
---|
55 |
|
---|
56 | #define ISDB(_l) ((_l)&db_level)
|
---|
57 |
|
---|
58 | #define DBS(_l,_x) do{ if(ISDB(_l)) {print_spaces (depth); \
|
---|
59 | printf _x; fflush (stdout);} }while(0)
|
---|
60 |
|
---|
61 | #define DBF(_l,_x) do{ if(ISDB(_l)) {print_spaces (depth); \
|
---|
62 | printf (_x, file->name); \
|
---|
63 | fflush (stdout);} }while(0)
|
---|
64 |
|
---|
65 | #define DB(_l,_x) do{ if(ISDB(_l)) {printf _x; fflush (stdout);} }while(0)
|
---|
66 |
|
---|
67 | #endif /* !KMK */
|
---|