preserve order in ref_vector::ensureUnique

metadata
Wenzel Jakob 2014-11-10 20:07:24 +01:00
parent 5a6be59fad
commit 461827ec11
1 changed files with 15 additions and 3 deletions

View File

@ -21,6 +21,7 @@
#define __MITSUBA_CORE_REF_H_ #define __MITSUBA_CORE_REF_H_
#include "util.h" #include "util.h"
#include <set>
MTS_NAMESPACE_BEGIN MTS_NAMESPACE_BEGIN
@ -148,10 +149,21 @@ public:
ref_vector(size_t size) : parent_type(size) {} ref_vector(size_t size) : parent_type(size) {}
ref_vector(const ref_vector &vec) : parent_type(vec) {} ref_vector(const ref_vector &vec) : parent_type(vec) {}
/// Remove all duplicates (may change the order) /// Remove all duplicates without changing the order
inline void ensureUnique() { inline void ensureUnique() {
std::sort(this->begin(), this->end(), ref_comparator<T>()); std::set<T *> seen;
this->erase(std::unique(this->begin(), this->end()), this->end());
typename parent_type::iterator it1 = this->begin(), it2 = this->begin();
for (; it1 < this->end(); ++it1) {
if (seen.find(it1->get()) != seen.end())
continue;
seen.insert(it1->get());
if (it1 != it2)
*it2++ = *it1;
else
it2++;
}
this->erase(it2, this->end());
} }
/// Check if a certain pointer is contained in the vector /// Check if a certain pointer is contained in the vector