summaryrefslogtreecommitdiff
path: root/libs/ardour/region_factory.cc
diff options
context:
space:
mode:
authorCarl Hetherington <carl@carlh.net>2012-05-15 00:06:26 +0000
committerCarl Hetherington <carl@carlh.net>2012-05-15 00:06:26 +0000
commit67b74ed1c7a3887ddd0e289c54c09ac8f7529518 (patch)
tree272dea61d51f64234b3ad9ffa77515b14009d915 /libs/ardour/region_factory.cc
parent5bbbc985338aec965237e9fdf3696ddff2bc1002 (diff)
Remove bind to shared_ptr.
git-svn-id: svn://localhost/ardour2/branches/3.0@12281 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'libs/ardour/region_factory.cc')
-rw-r--r--libs/ardour/region_factory.cc9
1 files changed, 7 insertions, 2 deletions
diff --git a/libs/ardour/region_factory.cc b/libs/ardour/region_factory.cc
index f739483821..b5195d80d9 100644
--- a/libs/ardour/region_factory.cc
+++ b/libs/ardour/region_factory.cc
@@ -321,7 +321,7 @@ RegionFactory::map_add (boost::shared_ptr<Region> r)
region_map.insert (p);
}
- r->DropReferences.connect_same_thread (region_list_connections, boost::bind (&RegionFactory::map_remove, r));
+ r->DropReferences.connect_same_thread (region_list_connections, boost::bind (&RegionFactory::map_remove, boost::weak_ptr<Region> (r)));
r->PropertyChanged.connect_same_thread (
region_list_connections,
@@ -332,8 +332,13 @@ RegionFactory::map_add (boost::shared_ptr<Region> r)
}
void
-RegionFactory::map_remove (boost::shared_ptr<Region> r)
+RegionFactory::map_remove (boost::weak_ptr<Region> w)
{
+ boost::shared_ptr<Region> r = w.lock ();
+ if (!r) {
+ return;
+ }
+
Glib::Mutex::Lock lm (region_map_lock);
RegionMap::iterator i = region_map.find (r->id());