summaryrefslogtreecommitdiff
path: root/lib/element.cpp
diff options
context:
space:
mode:
authorJosh Blum2013-04-03 23:58:52 -0700
committerJosh Blum2013-04-03 23:58:52 -0700
commit06b800166e995cf53ec0f87200427512e1518d8f (patch)
treecf75d446f986f0bee4976bd4d2d99ea1397cceff /lib/element.cpp
parentf7f459df3b1b4349138324b14703fc18bff7e2a6 (diff)
parentc85fe5cb75d32544eb89a573e8df61757a940766 (diff)
downloadsandhi-06b800166e995cf53ec0f87200427512e1518d8f.tar.gz
sandhi-06b800166e995cf53ec0f87200427512e1518d8f.tar.bz2
sandhi-06b800166e995cf53ec0f87200427512e1518d8f.zip
Merge branch 'ownership_work'
Diffstat (limited to 'lib/element.cpp')
-rw-r--r--lib/element.cpp27
1 files changed, 27 insertions, 0 deletions
diff --git a/lib/element.cpp b/lib/element.cpp
index 6736011..340bd85 100644
--- a/lib/element.cpp
+++ b/lib/element.cpp
@@ -31,6 +31,33 @@ Element::~Element(void)
//NOP
}
+//! Weak element overload for the case of shared_ptr container
+struct WeakElementSharedPtr : WeakElement
+{
+ WeakElementSharedPtr(boost::weak_ptr<Element> weak_self)
+ {
+ _weak_self = weak_self;
+ }
+ boost::shared_ptr<void> lock(void)
+ {
+ return _weak_self.lock();
+ }
+ boost::weak_ptr<Element> _weak_self;
+};
+
+Element &Element::shared_to_element(void)
+{
+ try
+ {
+ if (not this->weak_self)
+ {
+ this->weak_self.reset(new WeakElementSharedPtr(this->shared_from_this()));
+ }
+ }
+ catch(...){}
+ return *this;
+}
+
ElementImpl::~ElementImpl(void)
{
if (this->executor) this->top_block_cleanup();