new file
[ardour.git] / libs / ardour / ardour / debug.h
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 __ardour_debug_h__
21 #define __ardour_debug_h__
22
23 #include <stdint.h>
24
25 #include <sstream>
26
27 namespace ARDOUR {
28
29         extern uint64_t debug_bits;
30         void debug_print (const char* prefix, std::string str);
31         void set_debug_bits (uint64_t bits);
32         int parse_debug_options (const char* str);
33         void list_debug_options ();
34
35         namespace DEBUG {
36
37                 /* this namespace is so that we can write DEBUG::bit_name */
38
39                 enum DebugBits {
40                         MidiSourceIO = 0x1,
41                         MidiPlaylistIO = 0x2,
42                         MidiDiskstreamIO = 0x4,
43                         SnapBBT = 0x8,
44                         Configuration = 0x10,
45                         Latency = 0x20,
46                         Processors = 0x40,
47                         Graph = 0x80,
48                         Destruction = 0x100,
49                         MTC = 0x200,
50                         Transport = 0x400,
51                         Slave = 0x800,
52                         SessionEvents = 0x800,
53                         MidiIO = 0x1000,
54                         MackieControl = 0x2000,
55                         MidiClock = 0x4000
56                 };
57         }
58
59 }
60
61 #ifndef NDEBUG
62 #define DEBUG_TRACE(bits,str) if ((bits) & ARDOUR::debug_bits) { ARDOUR::debug_print (# bits, str); }
63 #define DEBUG_STR_DECL(id) std::stringstream __debug_str ## id;
64 #define DEBUG_STR(id) __debug_str ## id
65 #define DEBUG_STR_APPEND(id,s) __debug_str ## id << s;
66 #else
67 #define DEBUG_TRACE(bits,fmt,...) /*empty*/
68 #define DEBUG_STR(a) /* empty */
69 #define DEBUG_STR_APPEND(a,b) /* empty */
70 #endif
71
72 #endif /* __ardour_debug_h__ */
73