-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmy_log.h
39 lines (36 loc) · 1.4 KB
/
my_log.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
//
// Copyright 2015 by Kevin L. Goodwin [[email protected]]; All rights reserved
//
// This file is part of K.
//
// K is free software: you can redistribute it and/or modify it under the
// terms of the GNU General Public License as published by the Free Software
// Foundation, either version 3 of the License, or (at your option) any later
// version.
//
// K is distributed in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
// details.
//
// You should have received a copy of the GNU General Public License along
// with K. If not, see <http://www.gnu.org/licenses/>.
//
//
// Logging classes/APIs
//
#pragma once
#define NO_LOG 0
#if NO_LOG
// #define version does make smaller code, but causes almost 300 of "warning C4002: too many actual parameters for macro 'DBG'"
// #define DBG() (1)
// STIL version results in almost NO code size change since the params are all evaluated even if the function does nothing
STIL int DBG( char const *kszFormat, ... ) ATTR_FORMAT(1, 2) { return 1; }
STIL void DBG_init() {}
STIL void DBG_init() {}
STIL void DBGNL() {}
#else
extern int DBG( char const *kszFormat, ... ) ATTR_FORMAT(1, 2);
extern void DBGNL();
extern void DBG_init();
#endif