Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJacques Lucke <mail@jlucke.com>2019-09-14 15:41:19 +0300
committerJacques Lucke <mail@jlucke.com>2019-09-14 15:41:19 +0300
commita98760f7dad7948fc50613d2c39cb9cbe8a4fb08 (patch)
tree353411faffa99519c661e8bdfc84e1896a541f07 /source/blender/blenlib/BLI_vector_set.h
parent5b00ecf70bf6876d1279e8e8f73a5d722f77cb51 (diff)
BLI: speedup adding to VectorSet by removing a check
Diffstat (limited to 'source/blender/blenlib/BLI_vector_set.h')
-rw-r--r--source/blender/blenlib/BLI_vector_set.h14
1 files changed, 9 insertions, 5 deletions
diff --git a/source/blender/blenlib/BLI_vector_set.h b/source/blender/blenlib/BLI_vector_set.h
index c61643fa3d8..5de3ae298a7 100644
--- a/source/blender/blenlib/BLI_vector_set.h
+++ b/source/blender/blenlib/BLI_vector_set.h
@@ -115,19 +115,22 @@ template<typename T, typename Allocator = GuardedAllocator> class VectorSet {
Vector<T, 4, Allocator> m_elements;
public:
- VectorSet() = default;
+ VectorSet()
+ {
+ BLI_assert(m_array.slots_usable() <= m_elements.capacity());
+ }
- VectorSet(ArrayRef<T> values)
+ VectorSet(ArrayRef<T> values) : VectorSet()
{
this->add_multiple(values);
}
- VectorSet(const std::initializer_list<T> &values)
+ VectorSet(const std::initializer_list<T> &values) : VectorSet()
{
this->add_multiple(values);
}
- VectorSet(const Vector<T> &values)
+ VectorSet(const Vector<T> &values) : VectorSet()
{
this->add_multiple(values);
}
@@ -316,7 +319,7 @@ template<typename T, typename Allocator = GuardedAllocator> class VectorSet {
{
uint index = m_elements.size();
slot.set_index(index);
- m_elements.append(std::forward<ForwardT>(value));
+ m_elements.append_unchecked(std::forward<ForwardT>(value));
m_array.update__empty_to_set();
}
@@ -336,6 +339,7 @@ template<typename T, typename Allocator = GuardedAllocator> class VectorSet {
}
m_array = std::move(new_array);
+ m_elements.reserve(m_array.slots_usable());
}
void add_after_grow(uint index, ArrayType &new_array)