ref: 3d79f76e416c90223cb21cae118c41ace021da2c
parent: fdfedc45a62c14c226cc897d076f20453e587f7e
author: ISSOtm <[email protected]>
date: Mon Mar 7 17:51:47 EST 2022
Avoid calling `skipEmpty()` for `AssignedProtos::end()`
--- a/src/gfx/pal_packing.cpp
+++ b/src/gfx/pal_packing.cpp
@@ -89,13 +89,12 @@
Constness<decltype(_assigned)> *_array = nullptr;
Inner _iter{};
- Iter(decltype(_array) array, decltype(_iter) &&iter) : _array(array), _iter(iter) {
- skipEmpty();
- }
- void skipEmpty() {
+ Iter(decltype(_array) array, decltype(_iter) &&iter) : _array(array), _iter(iter) {}
+ Iter &skipEmpty() {
while (_iter != _array->end() && !_iter->has_value()) {
++_iter;
}
+ return *this;
}
public:
@@ -128,10 +127,12 @@
};
public:
using iterator = Iter<decltype(_assigned)::iterator, std::remove_const_t>;
- iterator begin() { return iterator{&_assigned, _assigned.begin()}; }
+ iterator begin() { return iterator{&_assigned, _assigned.begin()}.skipEmpty(); }
iterator end() { return iterator{&_assigned, _assigned.end()}; }
using const_iterator = Iter<decltype(_assigned)::const_iterator, std::add_const_t>;
- const_iterator begin() const { return const_iterator{&_assigned, _assigned.begin()}; }
+ const_iterator begin() const {
+ return const_iterator{&_assigned, _assigned.begin()}.skipEmpty();
+ }
const_iterator end() const { return const_iterator{&_assigned, _assigned.end()}; }
/**