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