blob: c204d6a5c6a0cc52fd0f036f78a8ec1405eff612 (
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
|
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
#pragma once
#include <vespa/vespalib/datastore/atomic_entry_ref.h>
#include <vespa/vespalib/datastore/entryref.h>
#include <vespa/vespalib/stllike/allocator.h>
#include <vespa/vespalib/util/rcuvector.h>
#include <vector>
namespace search::attribute {
using EntryRefVector = std::vector<vespalib::datastore::EntryRef, vespalib::allocator_large<vespalib::datastore::EntryRef>>;
/*
* Create a vector of entry refs from an rcu vector containing atomic
* entry refs. The new vector can be used by a flush thread while
* saving an attribute vector as long as the proper generation guard
* is also held.
*
* The function must be called from the attribute write thread.
*/
EntryRefVector make_entry_ref_vector_snapshot(const vespalib::RcuVectorBase<vespalib::datastore::AtomicEntryRef>& ref_vector, uint32_t size);
}
|