expose more info from plugin-strip (for GUI display)
[ardour.git] / libs / ardour / session_handle.cc
index 03671cfa68f132f299c66e787c824e1cb6ee0a33..99358dad0344f051089061627022b768204b9e25 100644 (file)
@@ -17,7 +17,9 @@
 
 */
 
+#include "pbd/demangle.h"
 #include "pbd/error.h"
+#include "pbd/boost_debug.h"
 
 #include "ardour/session.h"
 #include "ardour/session_handle.h"
@@ -29,12 +31,12 @@ using namespace ARDOUR;
 using namespace PBD;
 
 SessionHandlePtr::SessionHandlePtr (Session* s)
-       : _session (s) 
+       : _session (s)
 {
        if (_session) {
-               _session_connections.add_connection (_session->GoingAway.connect (boost::bind (&SessionHandlePtr::session_going_away, this)));
+               _session->DropReferences.connect_same_thread (_session_connections, boost::bind (&SessionHandlePtr::session_going_away, this));
        }
-}      
+}
 
 void
 SessionHandlePtr::set_session (Session* s)
@@ -47,7 +49,7 @@ SessionHandlePtr::set_session (Session* s)
 
        if (s) {
                _session = s;
-               _session_connections.add_connection (_session->GoingAway.connect (boost::bind (&SessionHandlePtr::session_going_away, this)));
+               _session->DropReferences.connect_same_thread (_session_connections, boost::bind (&SessionHandlePtr::session_going_away, this));
        }
 }
 
@@ -61,13 +63,31 @@ SessionHandlePtr::session_going_away ()
 
 
 SessionHandleRef::SessionHandleRef (Session& s)
-       : _session (s) 
+       : _session (s)
 {
-       scoped_connect (_session.GoingAway, boost::bind (&SessionHandleRef::session_going_away, this));
-}      
+       _session.DropReferences.connect_same_thread (*this, boost::bind (&SessionHandleRef::session_going_away, this));
+       _session.Destroyed.connect_same_thread (*this, boost::bind (&SessionHandleRef::insanity_check, this));
+}
+
+SessionHandleRef::~SessionHandleRef ()
+{
+}
 
 void
 SessionHandleRef::session_going_away ()
 {
-       error << string_compose (_("programming error: %1"), "SessionHandleRef exists across sesssion deletion!") << endmsg;
+       /* a handleRef is allowed to exist at the time of DropReferences, but not at the time of Destroyed
+        */
+}
+
+void
+SessionHandleRef::insanity_check ()
+{
+#ifndef NDEBUG
+       cerr << string_compose (
+               _("programming error: %1"),
+               string_compose("SessionHandleRef exists across session deletion! Dynamic type: %1 @ %2",
+                              PBD::demangled_name (*this), this))
+            << endl;
+#endif
 }