ardour
debug.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2009 Paul Davis
3 
4  This program is free software; you can redistribute it and/or modify
5  it under the terms of the GNU General Public License as published by
6  the Free Software Foundation; either version 2 of the License, or
7  (at your option) any later version.
8 
9  This program is distributed in the hope that it will be useful,
10  but WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  GNU General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License
15  along with this program; if not, write to the Free Software
16  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17 
18 */
19 
20 #ifndef __libpbd_debug_h__
21 #define __libpbd_debug_h__
22 
23 #include <stdint.h>
24 
25 #include <sstream>
26 
27 #include "pbd/libpbd_visibility.h"
28 #include "pbd/timing.h"
29 
30 namespace PBD {
31 
32  LIBPBD_API extern uint64_t debug_bits;
33  LIBPBD_API uint64_t new_debug_bit (const char* name);
34  LIBPBD_API void debug_print (const char* prefix, std::string str);
35  LIBPBD_API void set_debug_bits (uint64_t bits);
36  LIBPBD_API int parse_debug_options (const char* str);
38 
39  namespace DEBUG {
40 
41  /* this namespace is so that we can write DEBUG::bit_name */
42 
43  LIBPBD_API extern uint64_t Stateful;
44  LIBPBD_API extern uint64_t Properties;
45  LIBPBD_API extern uint64_t FileManager;
46  LIBPBD_API extern uint64_t Pool;
47  LIBPBD_API extern uint64_t EventLoop;
48  LIBPBD_API extern uint64_t AbstractUI;
49  LIBPBD_API extern uint64_t Configuration;
50  extern uint64_t FileUtils;
51  }
52 }
53 
54 #ifndef NDEBUG
55 #define DEBUG_TRACE(bits,str) if ((bits) & PBD::debug_bits) { PBD::debug_print (# bits, str); }
56 #define DEBUG_STR_DECL(id) std::stringstream __debug_str ## id;
57 #define DEBUG_STR(id) __debug_str ## id
58 #define DEBUG_STR_APPEND(id,s) __debug_str ## id << s;
59 #define DEBUG_ENABLED(bits) ((bits) & PBD::debug_bits)
60 #ifdef PTW32_VERSION
61 #define DEBUG_THREAD_SELF pthread_self().p
62 #else
63 #define DEBUG_THREAD_SELF pthread_self()
64 #endif
65 
66 #define DEBUG_TIMING_START(bits,td) if ((bits) & PBD::debug_bits) { td.start_timing (); }
67 #define DEBUG_TIMING_ADD_ELAPSED(bits,td) if ((bits) & PBD::debug_bits) { td.add_elapsed (); }
68 #define DEBUG_TIMING_RESET(bits,td) if ((bits) & PBD::debug_bits) { td.reset (); }
69 
70 #else
71 #define DEBUG_TRACE(bits,fmt,...) /*empty*/
72 #define DEBUG_STR(a) /* empty */
73 #define DEBUG_STR_APPEND(a,b) /* empty */
74 #define DEBUG_ENABLED(b) (0)
75 #define DEBUG_THREAD_SELF 0
76 
77 #define DEBUG_TIMING_START(bits,td) /*empty*/
78 #define DEBUG_TIMING_ADD_ELAPSED(bits,td) /*empty*/
79 #define DEBUG_TIMING_RESET(bits,td) /*empty*/
80 
81 #endif
82 #endif /* __libpbd_debug_h__ */
83 
LIBPBD_API uint64_t Pool
Definition: debug.cc:49
#define LIBPBD_API
#define DEBUG(format,...)
LIBPBD_API void debug_print(const char *prefix, std::string str)
LIBPBD_API void set_debug_bits(uint64_t bits)
Definition: debug.cc:74
LIBPBD_API uint64_t FileManager
Definition: debug.cc:48
LIBPBD_API uint64_t Configuration
Definition: debug.cc:53
LIBPBD_API uint64_t Properties
Definition: debug.cc:47
LIBPBD_API uint64_t AbstractUI
Definition: debug.cc:51
LIBPBD_API uint64_t debug_bits
Definition: debug.cc:55
const char * name
LIBPBD_API void list_debug_options()
Definition: debug.cc:113
Definition: debug.h:30
LIBPBD_API uint64_t Stateful
Definition: debug.cc:46
uint64_t FileUtils
Definition: debug.cc:52
LIBPBD_API uint64_t EventLoop
Definition: debug.cc:50
LIBPBD_API uint64_t new_debug_bit(const char *name)
Definition: debug.cc:58
LIBPBD_API int parse_debug_options(const char *str)
Definition: debug.cc:80