diff options
author | Josh Blum | 2013-04-03 23:31:34 -0700 |
---|---|---|
committer | Josh Blum | 2013-04-03 23:31:34 -0700 |
commit | c85fe5cb75d32544eb89a573e8df61757a940766 (patch) | |
tree | a1e0fb013bb2d31823738f5ab7de7b69316193ed /lib/element.cpp | |
parent | 0651aff49ae7e066bc301faeecfbd519c4743849 (diff) | |
download | sandhi-c85fe5cb75d32544eb89a573e8df61757a940766.tar.gz sandhi-c85fe5cb75d32544eb89a573e8df61757a940766.tar.bz2 sandhi-c85fe5cb75d32544eb89a573e8df61757a940766.zip |
gras: code cleanup and comments from last commit
Diffstat (limited to 'lib/element.cpp')
-rw-r--r-- | lib/element.cpp | 27 |
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(); |