summaryrefslogtreecommitdiffstats
path: root/include/query/irs.h
diff options
context:
space:
mode:
authorDouglas Rumbaugh <dbr4@psu.edu>2024-02-05 15:17:25 -0500
committerDouglas Rumbaugh <dbr4@psu.edu>2024-02-05 15:17:25 -0500
commitdb4806d9dd9757273a14e6c3ea92e5a087239145 (patch)
tree3766b79180d9d3b2167b0ff8d74cd9e73bfc5298 /include/query/irs.h
parentfca660859bd8133cff53592b17abf4c8a51fc2c0 (diff)
downloaddynamic-extension-db4806d9dd9757273a14e6c3ea92e5a087239145.tar.gz
Set up tombstone deletes properly
Diffstat (limited to 'include/query/irs.h')
-rw-r--r--include/query/irs.h16
1 files changed, 8 insertions, 8 deletions
diff --git a/include/query/irs.h b/include/query/irs.h
index 7ef5069..7eea14b 100644
--- a/include/query/irs.h
+++ b/include/query/irs.h
@@ -39,9 +39,9 @@ struct BufferState {
size_t cutoff;
std::vector<Wrapped<R>> records;
size_t sample_size;
- BufferView<R> buffer;
+ BufferView<R> *buffer;
- BufferState(BufferView<R> buffer) : buffer(std::move(buffer)) {}
+ BufferState(BufferView<R> *buffer) : buffer(buffer) {}
};
template <ShardInterface S, RecordInterface R, bool Rejection=true>
@@ -68,10 +68,10 @@ public:
return res;
}
- static void* get_buffer_query_state(BufferView<R> buffer, void *parms) {
- auto res = new BufferState<R>(std::move(buffer));
+ static void* get_buffer_query_state(BufferView<R> *buffer, void *parms) {
+ auto res = new BufferState<R>(buffer);
- res->cutoff = res->buffer.get_record_count();
+ res->cutoff = res->buffer->get_record_count();
res->sample_size = 0;
if constexpr (Rejection) {
@@ -82,8 +82,8 @@ public:
auto upper_key = ((Parms<R> *) parms)->upper_bound;
for (size_t i=0; i<res->cutoff; i++) {
- if ((res->buffer.get(i)->rec.key >= lower_key) && (buffer.get(i)->rec.key <= upper_key)) {
- res->records.emplace_back(*(res->buffer.get(i)));
+ if ((res->buffer->get(i)->rec.key >= lower_key) && (buffer->get(i)->rec.key <= upper_key)) {
+ res->records.emplace_back(*(res->buffer->get(i)));
}
}
@@ -181,7 +181,7 @@ public:
if constexpr (Rejection) {
for (size_t i=0; i<st->sample_size; i++) {
auto idx = gsl_rng_uniform_int(p->rng, st->cutoff);
- auto rec = st->buffer.get(idx);
+ auto rec = st->buffer->get(idx);
if (rec->rec.key >= p->lower_bound && rec->rec.key <= p->upper_bound) {
result.emplace_back(*rec);