|
|
@ -83,6 +83,10 @@ public:
|
|
|
|
using iterator = iterator_impl<T>;
|
|
|
|
using iterator = iterator_impl<T>;
|
|
|
|
using const_iterator = iterator_impl<const T>;
|
|
|
|
using const_iterator = iterator_impl<const T>;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
base_optional_span() = default;
|
|
|
|
|
|
|
|
base_optional_span(Vec&& v, size_t nof_elems_) : vec(std::move(v)), nof_elems(nof_elems_) {}
|
|
|
|
|
|
|
|
base_optional_span(const Vec& v, size_t nof_elems_) : vec(v), nof_elems(nof_elems_) {}
|
|
|
|
|
|
|
|
|
|
|
|
// Find first position that is empty
|
|
|
|
// Find first position that is empty
|
|
|
|
size_t find_first_empty(size_t start_guess = 0)
|
|
|
|
size_t find_first_empty(size_t start_guess = 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -134,6 +138,16 @@ public:
|
|
|
|
this->nof_elems += this->contains(idx) ? 0 : 1;
|
|
|
|
this->nof_elems += this->contains(idx) ? 0 : 1;
|
|
|
|
this->vec[idx] = std::forward<U>(u);
|
|
|
|
this->vec[idx] = std::forward<U>(u);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
template <typename... Args>
|
|
|
|
|
|
|
|
void emplace(size_t idx, Args&&... args)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
srsran_assert(idx < this->vec.size(), "Out-of-bounds access to array: %zd>=%zd", idx, this->vec.size());
|
|
|
|
|
|
|
|
if (not this->contains(idx)) {
|
|
|
|
|
|
|
|
this->nof_elems++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
this->vec[idx].emplace(std::forward<Args>(args)...);
|
|
|
|
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
template <typename Vec>
|
|
|
|
template <typename Vec>
|
|
|
@ -148,8 +162,7 @@ public:
|
|
|
|
|
|
|
|
|
|
|
|
base_optional_vector() = default;
|
|
|
|
base_optional_vector() = default;
|
|
|
|
base_optional_vector(const base_optional_vector&) = default;
|
|
|
|
base_optional_vector(const base_optional_vector&) = default;
|
|
|
|
base_optional_vector(base_optional_vector&& other) noexcept : base_t::vec(std::move(other.vec)),
|
|
|
|
base_optional_vector(base_optional_vector&& other) noexcept : base_t(std::move(other.vec), other.size())
|
|
|
|
base_t::nof_elems(other.nof_elems)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
other.nof_elems = 0;
|
|
|
|
other.nof_elems = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -158,7 +171,7 @@ public:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
this->vec = std::move(other.vec);
|
|
|
|
this->vec = std::move(other.vec);
|
|
|
|
this->nof_elems = other.nof_elems;
|
|
|
|
this->nof_elems = other.nof_elems;
|
|
|
|
this->nof_elems = 0;
|
|
|
|
other.nof_elems = 0;
|
|
|
|
return *this;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
@ -196,6 +209,16 @@ public:
|
|
|
|
}
|
|
|
|
}
|
|
|
|
base_t::insert(idx, std::forward<U>(u));
|
|
|
|
base_t::insert(idx, std::forward<U>(u));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// May allocate and cause pointer invalidation
|
|
|
|
|
|
|
|
template <typename... Args>
|
|
|
|
|
|
|
|
void emplace(size_t idx, Args&&... args)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (idx >= this->vec.size()) {
|
|
|
|
|
|
|
|
this->vec.resize(idx + 1);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
base_t::emplace(idx, std::forward<Args>(args)...);
|
|
|
|
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
template <typename T>
|
|
|
|