8#include <gtest/gtest.h>
19 EXPECT_EQ(a.size(), b.size());
20 for (
size_t i = 0; i < a.size(); ++i) {
21 EXPECT_EQ(a[i], b[i]);
36 fData = {1, 2, 3, 4, 5, 6, 7, 8, 9};
50 EXPECT_EQ(vec.
Size(0), 2);
52 EXPECT_EQ(vec.
Size(0), 2);
53 EXPECT_EQ(vec[0].
size(), 2);
58 EXPECT_EQ(part.first.size(), vec.
Size(0));
59 EXPECT_EQ(part.second, vec.
Address(0));
61 EXPECT_EQ(vec.
Size(1), 4);
62 EXPECT_EQ(vec[1].
size(), 4);
63 EXPECT_EQ(vec.
Address(1), 0x100);
67 EXPECT_EQ(part.first.size(), vec.
Size(1));
68 EXPECT_EQ(part.second, vec.
Address(1));
70 EXPECT_EQ(vec.
Size(2), 3);
71 EXPECT_EQ(vec[2].
size(), 3);
72 EXPECT_EQ(vec.
Address(2), 0x200);
76 EXPECT_EQ(part.first.size(), vec.
Size(2));
77 EXPECT_EQ(part.second, vec.
Address(2));
120 EXPECT_THROW(
PartitionedSpan vec(fData, fOffsets, fAddressesInvalid), std::runtime_error);
125 EXPECT_THROW(
PartitionedSpan vec(fData, fOffsetsInvalid, fAddresses), std::runtime_error);
132 EXPECT_THROW(vec[3], std::out_of_range);
133 EXPECT_THROW(vec.
Partition(3), std::out_of_range);
134 EXPECT_THROW(vec.
Address(3), std::out_of_range);
135 EXPECT_THROW(vec.
Size(3), std::out_of_range);
static constexpr size_t size()
void EXPECT_CONTAINER_EQ(gsl::span< T > a, std::vector< int32_t > b)
TEST_F(PartitionedSpanTest, IsDefaultConstructable)
std::vector< uint32_t > fAddressesInvalid
std::vector< size_t > fSizes
std::vector< size_t > fOffsets
std::vector< size_t > fOffsetsInvalid
std::vector< int32_t > fData
std::vector< uint32_t > fAddresses
void Ensure(const PartitionedSpan< T > &vec)
std::pair< gsl::span< T >, uint32_t > Partition(size_t i) const
size_t NPartitions() const
size_t Size(size_t i) const
uint32_t Address(size_t i) const
A vector that is partitioned into multiple subvectors.