[ADT] Add convenience function filter_to_vector (#117460)

This materializes a filter range as a small vector.

Similar to `map_to_vector`, this new utility function lives in the
`SmallVectorExtras.h` header.
This commit is contained in:
Jakub Kuderski
2024-11-25 10:26:51 -05:00
committed by GitHub
parent 7800d59f5b
commit f9dca5bdbb
3 changed files with 54 additions and 0 deletions

View File

@@ -19,12 +19,28 @@
namespace llvm {
/// Filter a range to a SmallVector with the element types deduced.
template <unsigned Size, class ContainerTy, class PredicateFn>
auto filter_to_vector(ContainerTy &&C, PredicateFn &&Pred) {
return to_vector<Size>(make_filter_range(std::forward<ContainerTy>(C),
std::forward<PredicateFn>(Pred)));
}
/// Filter a range to a SmallVector with the element types deduced.
template <class ContainerTy, class PredicateFn>
auto filter_to_vector(ContainerTy &&C, PredicateFn &&Pred) {
return to_vector(make_filter_range(std::forward<ContainerTy>(C),
std::forward<PredicateFn>(Pred)));
}
/// Map a range to a SmallVector with element types deduced from the mapping.
template <unsigned Size, class ContainerTy, class FuncTy>
auto map_to_vector(ContainerTy &&C, FuncTy &&F) {
return to_vector<Size>(
map_range(std::forward<ContainerTy>(C), std::forward<FuncTy>(F)));
}
/// Map a range to a SmallVector with element types deduced from the mapping.
template <class ContainerTy, class FuncTy>
auto map_to_vector(ContainerTy &&C, FuncTy &&F) {
return to_vector(

View File

@@ -75,6 +75,7 @@ add_llvm_unittest(ADTTests
SmallPtrSetTest.cpp
SmallSetTest.cpp
SmallStringTest.cpp
SmallVectorExtrasTest.cpp
SmallVectorTest.cpp
SparseBitVectorTest.cpp
SparseMultiSetTest.cpp

View File

@@ -0,0 +1,37 @@
//===- llvm/unittest/ADT/SmallVectorExtrasTest.cpp ------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// SmallVectorExtras unit tests.
//
//===----------------------------------------------------------------------===//
#include "llvm/ADT/SmallVectorExtras.h"
#include "gmock/gmock.h"
#include "gtest/gtest.h"
#include <type_traits>
#include <vector>
using testing::ElementsAre;
namespace llvm {
namespace {
TEST(SmallVectorExtrasTest, FilterToVector) {
std::vector<int> Numbers = {0, 1, 2, 3, 4};
auto Odd = filter_to_vector<2>(Numbers, [](int X) { return (X % 2) != 0; });
static_assert(std::is_same_v<decltype(Odd), SmallVector<int, 2>>);
EXPECT_THAT(Odd, ElementsAre(1, 3));
auto Even = filter_to_vector(Numbers, [](int X) { return (X % 2) == 0; });
static_assert(std::is_same_v<decltype(Even), SmallVector<int>>);
EXPECT_THAT(Even, ElementsAre(0, 2, 4));
}
} // end namespace
} // namespace llvm