diff options
author | Max Kellermann <max@duempel.org> | 2014-09-28 19:18:48 +0200 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2014-10-01 19:49:38 +0200 |
commit | fb4e6ac923574a8544c94e4deceaf774a4e2504c (patch) | |
tree | ff4a449789f613ad0e08d6ca86560b5dbbb3a475 /src/lib/nfs/Cancellable.hxx | |
parent | 3560dc4be60e6e3c47c687b9702a62a610909546 (diff) | |
download | mpd-fb4e6ac923574a8544c94e4deceaf774a4e2504c.tar.gz mpd-fb4e6ac923574a8544c94e4deceaf774a4e2504c.tar.xz mpd-fb4e6ac923574a8544c94e4deceaf774a4e2504c.zip |
lib/nfs/Cancellable: use boost::intrusive::list
Reduce Remove() overhead because we don't have to walk the list to
find an iterator by reference.
Diffstat (limited to 'src/lib/nfs/Cancellable.hxx')
-rw-r--r-- | src/lib/nfs/Cancellable.hxx | 48 |
1 files changed, 13 insertions, 35 deletions
diff --git a/src/lib/nfs/Cancellable.hxx b/src/lib/nfs/Cancellable.hxx index 50762b582..1f287c329 100644 --- a/src/lib/nfs/Cancellable.hxx +++ b/src/lib/nfs/Cancellable.hxx @@ -22,13 +22,15 @@ #include "Compiler.h" -#include <list> +#include <boost/intrusive/list.hpp> + #include <algorithm> #include <assert.h> template<typename T> -class CancellablePointer { +class CancellablePointer + : public boost::intrusive::list_base_hook<boost::intrusive::link_mode<boost::intrusive::normal_link>> { public: typedef T *pointer_type; typedef T &reference_type; @@ -38,7 +40,7 @@ private: pointer_type p; public: - explicit constexpr CancellablePointer(reference_type _p):p(&_p) {} + explicit CancellablePointer(reference_type _p):p(&_p) {} CancellablePointer(const CancellablePointer &) = delete; @@ -70,7 +72,8 @@ public: typedef typename CT::const_reference_type const_reference_type; private: - typedef std::list<CT> List; + typedef boost::intrusive::list<CT, + boost::intrusive::constant_time_size<false>> List; typedef typename List::iterator iterator; typedef typename List::const_iterator const_iterator; List list; @@ -97,28 +100,14 @@ private: return std::find_if(list.begin(), list.end(), MatchPointer(p)); } - class MatchReference { - const CT &c; - - public: - constexpr explicit MatchReference(const CT &_c):c(_c) {} - - gcc_pure - bool operator()(const CT &a) const { - return &a == &c; - } - }; - gcc_pure iterator Find(CT &c) { - return std::find_if(list.begin(), list.end(), - MatchReference(c)); + return list.iterator_to(c); } gcc_pure const_iterator Find(const CT &c) const { - return std::find_if(list.begin(), list.end(), - MatchReference(c)); + return list.iterator_to(c); } public: @@ -142,21 +131,9 @@ public: CT &Add(reference_type p, Args&&... args) { assert(Find(p) == list.end()); - list.emplace_back(p, std::forward<Args>(args)...); - return list.back(); - } - - void RemoveLast() { - list.pop_back(); - } - - bool RemoveOptional(CT &ct) { - auto i = Find(ct); - if (i == list.end()) - return false; - - list.erase(i); - return true; + CT *c = new CT(p, std::forward<Args>(args)...); + list.push_back(*c); + return *c; } void Remove(CT &ct) { @@ -164,6 +141,7 @@ public: assert(i != list.end()); list.erase(i); + delete &ct; } void Cancel(reference_type p) { |