blob: d2cd0a10710ae9247e7767bb492ff8851b2b2001 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
//
#pragma once
#include "polymorphicarray.h"
#include <vespa/vespalib/util/memory.h>
#include <vector>
namespace vespalib {
template <typename T, typename B>
class PrimitiveArrayT final : public IArrayT<B>
{
using typename IArrayT<B>::iterator;
public:
PrimitiveArrayT() : _array() { }
~PrimitiveArrayT() { }
const T & operator [] (size_t i) const override { return _array[i]; }
T & operator [] (size_t i) override { return _array[i]; }
void resize(size_t sz) override { _array.resize(sz); }
void reserve(size_t sz) override { _array.reserve(sz); }
void clear() override { _array.clear(); }
IArrayT<B> * clone() const override { return new PrimitiveArrayT<T, B>(*this); }
size_t size() const override { return _array.size(); }
iterator erase(iterator it) override { _array.erase(_array.begin() + (it - this->begin())); return it; }
void push_back(const B & v) override {
_array.emplace_back();
_array.back().assign(v);
}
private:
std::vector<T> _array;
};
template <typename B>
class ComplexArrayT final : public IArrayT<B>
{
using typename IArrayT<B>::iterator;
public:
class Factory {
public:
using UP = std::unique_ptr<Factory>;
using CP = vespalib::CloneablePtr<Factory>;
virtual B * create() = 0;
virtual Factory * clone() const = 0;
virtual ~Factory() { }
};
explicit ComplexArrayT(typename Factory::UP factory) : _array(), _factory(factory.release()) { }
~ComplexArrayT() { }
const B & operator [] (size_t i) const override { return *_array[i]; }
B & operator [] (size_t i) override { return *_array[i]; }
void resize(size_t sz) override {
_array.resize(sz);
for (auto & cp : _array) {
if ( cp.get() == nullptr) {
cp.reset(_factory->create());
}
}
}
void reserve(size_t sz) override { _array.reserve(sz); }
void clear() override { _array.clear(); }
IArrayT<B> * clone() const override { return new ComplexArrayT<B>(*this); }
size_t size() const override { return _array.size(); }
iterator erase(iterator it) override { _array.erase(_array.begin() + (it - this->begin())); return it; }
void push_back(const B & v) override { _array.push_back(v.clone()); }
private:
using CP = vespalib::CloneablePtr<B>;
std::vector<CP> _array;
typename Factory::CP _factory;
};
}
|