projects
/
ardour.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Use hyphen for XML property names
[ardour.git]
/
libs
/
pbd
/
pbd
/
signals.h
diff --git
a/libs/pbd/pbd/signals.h
b/libs/pbd/pbd/signals.h
index 3896fd55b5655fd4af0f19e08cc4242861989925..df4c9cef29331c5d3b0477143d932e0c7fc4df8e 100644
(file)
--- a/
libs/pbd/pbd/signals.h
+++ b/
libs/pbd/pbd/signals.h
@@
-1,6
+1,6
@@
/*
/*
- Copyright (C) 2009-2012 Paul Davis
-
+ Copyright (C) 2009-2012 Paul Davis
+
This program 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 2 of the License, or
This program 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 2 of the License, or
@@
-20,6
+20,8
@@
#ifndef __pbd_signals_h__
#define __pbd_signals_h__
#ifndef __pbd_signals_h__
#define __pbd_signals_h__
+#include <csignal>
+
#include <list>
#include <map>
#include <list>
#include <map>
@@
-39,6
+41,15
@@
#include "pbd/libpbd_visibility.h"
#include "pbd/event_loop.h"
#include "pbd/libpbd_visibility.h"
#include "pbd/event_loop.h"
+#ifndef NDEBUG
+#define DEBUG_PBD_SIGNAL_CONNECTIONS
+#endif
+
+#ifdef DEBUG_PBD_SIGNAL_CONNECTIONS
+#include "pbd/stacktrace.h"
+#include <iostream>
+#endif
+
namespace PBD {
class LIBPBD_API Connection;
namespace PBD {
class LIBPBD_API Connection;
@@
-46,17
+57,33
@@
class LIBPBD_API Connection;
class LIBPBD_API SignalBase
{
public:
class LIBPBD_API SignalBase
{
public:
+ SignalBase ()
+#ifdef DEBUG_PBD_SIGNAL_CONNECTIONS
+ : _debug_connection (false)
+#endif
+ {}
virtual ~SignalBase () {}
virtual void disconnect (boost::shared_ptr<Connection>) = 0;
virtual ~SignalBase () {}
virtual void disconnect (boost::shared_ptr<Connection>) = 0;
+#ifdef DEBUG_PBD_SIGNAL_CONNECTIONS
+ void set_debug_connection (bool yn) { _debug_connection = yn; }
+#endif
protected:
protected:
- Glib::Threads::Mutex _mutex;
+ mutable Glib::Threads::Mutex _mutex;
+#ifdef DEBUG_PBD_SIGNAL_CONNECTIONS
+ bool _debug_connection;
+#endif
};
class LIBPBD_API Connection : public boost::enable_shared_from_this<Connection>
{
public:
};
class LIBPBD_API Connection : public boost::enable_shared_from_this<Connection>
{
public:
- Connection (SignalBase* b) : _signal (b) {}
+ Connection (SignalBase* b, PBD::EventLoop::InvalidationRecord* ir) : _signal (b), _invalidation_record (ir)
+ {
+ if (_invalidation_record) {
+ _invalidation_record->ref ();
+ }
+ }
void disconnect ()
{
void disconnect ()
{
@@
-67,19
+94,30
@@
public:
}
}
}
}
+ void disconnected ()
+ {
+ if (_invalidation_record) {
+ _invalidation_record->unref ();
+ }
+ }
+
void signal_going_away ()
{
Glib::Threads::Mutex::Lock lm (_mutex);
void signal_going_away ()
{
Glib::Threads::Mutex::Lock lm (_mutex);
+ if (_invalidation_record) {
+ _invalidation_record->unref ();
+ }
_signal = 0;
}
private:
Glib::Threads::Mutex _mutex;
SignalBase* _signal;
_signal = 0;
}
private:
Glib::Threads::Mutex _mutex;
SignalBase* _signal;
+ PBD::EventLoop::InvalidationRecord* _invalidation_record;
};
template<typename R>
};
template<typename R>
-class
LIBPBD_API
OptionalLastValue
+class
/*LIBPBD_API*/
OptionalLastValue
{
public:
typedef boost::optional<R> result_type;
{
public:
typedef boost::optional<R> result_type;
@@
-95,9
+133,9
@@
public:
return r;
}
};
return r;
}
};
-
+
typedef boost::shared_ptr<Connection> UnscopedConnection;
typedef boost::shared_ptr<Connection> UnscopedConnection;
-
+
class LIBPBD_API ScopedConnection
{
public:
class LIBPBD_API ScopedConnection
{
public:
@@
-119,7
+157,7
@@
public:
if (_c == o) {
return *this;
}
if (_c == o) {
return *this;
}
-
+
disconnect ();
_c = o;
return *this;
disconnect ();
_c = o;
return *this;
@@
-128,13
+166,13
@@
public:
private:
UnscopedConnection _c;
};
private:
UnscopedConnection _c;
};
-
+
class LIBPBD_API ScopedConnectionList : public boost::noncopyable
{
public:
ScopedConnectionList();
virtual ~ScopedConnectionList ();
class LIBPBD_API ScopedConnectionList : public boost::noncopyable
{
public:
ScopedConnectionList();
virtual ~ScopedConnectionList ();
-
+
void add_connection (const UnscopedConnection& c);
void drop_connections ();
void add_connection (const UnscopedConnection& c);
void drop_connections ();
@@
-146,9
+184,9
@@
class LIBPBD_API ScopedConnectionList : public boost::noncopyable
scoped connections needs to be protected in 2 cases:
(1) (unlikely) we make a connection involving a callback on the
scoped connections needs to be protected in 2 cases:
(1) (unlikely) we make a connection involving a callback on the
- same object from 2 threads. (wouldn't that just be appalling
+ same object from 2 threads. (wouldn't that just be appalling
programming style?)
programming style?)
-
+
(2) where we are dropping connections in one thread and adding
one from another.
*/
(2) where we are dropping connections in one thread and adding
one from another.
*/
@@
-159,8
+197,8
@@
class LIBPBD_API ScopedConnectionList : public boost::noncopyable
ConnectionList _list;
};
ConnectionList _list;
};
-#include "pbd/signals_generated.h"
-
+#include "pbd/signals_generated.h"
+
} /* namespace */
#endif /* __pbd_signals_h__ */
} /* namespace */
#endif /* __pbd_signals_h__ */