summaryrefslogtreecommitdiff
path: root/libs/pbd/debug.cc
diff options
context:
space:
mode:
authorSakari Bergen <sakari.bergen@beatwaves.net>2013-03-24 21:18:20 +0200
committerSakari Bergen <sakari.bergen@beatwaves.net>2013-03-24 21:18:20 +0200
commitb6c2dec8fa2a3a1041080654b61bb4072e6fd09f (patch)
tree3185bfa6ed3489d90a53d08055c29b8a66f0fd1e /libs/pbd/debug.cc
parent24816de6ca577eb36c1ce2bd6605303d3c9a9419 (diff)
Fix static initialization order problem
Diffstat (limited to 'libs/pbd/debug.cc')
-rw-r--r--libs/pbd/debug.cc12
1 files changed, 8 insertions, 4 deletions
diff --git a/libs/pbd/debug.cc b/libs/pbd/debug.cc
index 98d0fc5091..c86afbe87e 100644
--- a/libs/pbd/debug.cc
+++ b/libs/pbd/debug.cc
@@ -34,7 +34,11 @@ static uint64_t _debug_bit = 1;
typedef std::map<const char*,uint64_t> DebugMap;
namespace PBD {
- DebugMap _debug_bit_map;
+ DebugMap & _debug_bit_map()
+ {
+ static DebugMap map;
+ return map;
+ }
}
uint64_t PBD::DEBUG::Stateful = PBD::new_debug_bit ("stateful");
@@ -50,7 +54,7 @@ uint64_t
PBD::new_debug_bit (const char* name)
{
uint64_t ret;
- _debug_bit_map.insert (make_pair (name, _debug_bit));
+ _debug_bit_map().insert (make_pair (name, _debug_bit));
ret = _debug_bit;
_debug_bit <<= 1;
return ret;
@@ -91,7 +95,7 @@ PBD::parse_debug_options (const char* str)
return 0;
}
- for (map<const char*,uint64_t>::iterator i = _debug_bit_map.begin(); i != _debug_bit_map.end(); ++i) {
+ for (map<const char*,uint64_t>::iterator i = _debug_bit_map().begin(); i != _debug_bit_map().end(); ++i) {
if (strncasecmp (p, i->first, strlen (p)) == 0) {
bits |= i->second;
}
@@ -113,7 +117,7 @@ PBD::list_debug_options ()
vector<string> options;
- for (map<const char*,uint64_t>::iterator i = _debug_bit_map.begin(); i != _debug_bit_map.end(); ++i) {
+ for (map<const char*,uint64_t>::iterator i = _debug_bit_map().begin(); i != _debug_bit_map().end(); ++i) {
options.push_back (i->first);
}