summaryrefslogtreecommitdiffstats
path: root/include/query
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
parentfca660859bd8133cff53592b17abf4c8a51fc2c0 (diff)
downloaddynamic-extension-db4806d9dd9757273a14e6c3ea92e5a087239145.tar.gz
Set up tombstone deletes properly
Diffstat (limited to 'include/query')
-rw-r--r--include/query/irs.h16
-rw-r--r--include/query/rangecount.h14
-rw-r--r--include/query/rangequery.h14
3 files changed, 22 insertions, 22 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);
diff --git a/include/query/rangecount.h b/include/query/rangecount.h
index 7d88b1d..70d57d8 100644
--- a/include/query/rangecount.h
+++ b/include/query/rangecount.h
@@ -33,10 +33,10 @@ struct State {
template <RecordInterface R>
struct BufferState {
- BufferView<R> buffer;
+ BufferView<R> *buffer;
- BufferState(BufferView<R> buffer)
- : buffer(std::move(buffer)) {}
+ BufferState(BufferView<R> *buffer)
+ : buffer(buffer) {}
};
template <ShardInterface S, KVPInterface R>
@@ -55,8 +55,8 @@ 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);
return res;
}
@@ -123,8 +123,8 @@ public:
res.rec.value = 0; // tombstones
records.emplace_back(res);
- for (size_t i=0; i<s->buffer.get_record_count(); i++) {
- auto rec = s->buffer.get(i);
+ for (size_t i=0; i<s->buffer->get_record_count(); i++) {
+ auto rec = s->buffer->get(i);
if (rec->rec.key >= p->lower_bound && rec->rec.key <= p->upper_bound
&& !rec->is_deleted()) {
if (rec->is_tombstone()) {
diff --git a/include/query/rangequery.h b/include/query/rangequery.h
index c44f5d7..1a42265 100644
--- a/include/query/rangequery.h
+++ b/include/query/rangequery.h
@@ -32,10 +32,10 @@ struct State {
template <RecordInterface R>
struct BufferState {
- 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>
@@ -54,8 +54,8 @@ 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);
return res;
}
@@ -101,8 +101,8 @@ public:
auto s = (BufferState<R> *) state;
std::vector<Wrapped<R>> records;
- for (size_t i=0; i<s->buffer.get_record_count(); i++) {
- auto rec = s->buffer.get(i);
+ for (size_t i=0; i<s->buffer->get_record_count(); i++) {
+ auto rec = s->buffer->get(i);
if (rec->rec.key >= p->lower_bound && rec->rec.key <= p->upper_bound) {
records.emplace_back(*rec);
}