Bug 1595750 - Add MakeBackInserter function to create a back-inserting output iterator for nsTArray. r=froydnj

Differential Revision: https://phabricator.services.mozilla.com/D52685

--HG--
extra : moz-landing-system : lando
This commit is contained in:
Simon Giesecke 2019-11-12 15:52:24 +00:00
parent 8088fe5c1d
commit e0f8b73760
2 changed files with 35 additions and 0 deletions

View File

@ -2730,6 +2730,30 @@ Span<const ElementType> MakeSpan(
return aTArray;
}
template <typename T>
class nsTArrayBackInserter
: public std::iterator<std::output_iterator_tag, void, void, void, void> {
nsTArray<T>& mArray;
public:
explicit nsTArrayBackInserter(nsTArray<T>& aArray) : mArray{aArray} {}
template <typename O>
nsTArrayBackInserter& operator=(O&& aValue) {
mArray.EmplaceBack(std::forward<O>(aValue));
return *this;
}
nsTArrayBackInserter& operator*() { return *this; }
void operator++() {}
};
template <typename T>
auto MakeBackInserter(nsTArray<T>& aArray) {
return nsTArrayBackInserter<T>{aArray};
}
} // namespace mozilla
// MOZ_DBG support

View File

@ -443,4 +443,15 @@ TEST(TArray, RemoveElementsAt_ByIterator)
ASSERT_EQ(expected, array);
}
TEST(TArray, MakeBackInserter)
{
const std::vector<int> src{1, 2, 3, 4};
nsTArray<int> dst;
std::copy(src.begin(), src.end(), MakeBackInserter(dst));
const nsTArray<int> expected{1, 2, 3, 4};
ASSERT_EQ(expected, dst);
}
} // namespace TestTArray