summaryrefslogtreecommitdiffstats
path: root/include
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
parentfca660859bd8133cff53592b17abf4c8a51fc2c0 (diff)
downloaddynamic-extension-db4806d9dd9757273a14e6c3ea92e5a087239145.tar.gz
Set up tombstone deletes properly
Diffstat (limited to 'include')
-rw-r--r--include/framework/DynamicExtension.h14
-rw-r--r--include/query/irs.h16
-rw-r--r--include/query/rangecount.h14
-rw-r--r--include/query/rangequery.h14
4 files changed, 32 insertions, 26 deletions
diff --git a/include/framework/DynamicExtension.h b/include/framework/DynamicExtension.h
index a56cc6c..3e9d0fb 100644
--- a/include/framework/DynamicExtension.h
+++ b/include/framework/DynamicExtension.h
@@ -481,7 +481,7 @@ private:
void *parms = args->query_parms;
/* Get the buffer query states */
- void *buffer_state = Q::get_buffer_query_state(std::move(buffer), parms);
+ void *buffer_state = Q::get_buffer_query_state(&buffer, parms);
/* Get the shard query states */
std::vector<std::pair<ShardID, Shard*>> shards;
@@ -502,7 +502,7 @@ private:
shid = shards[i - 1].first;
}
- query_results[i] = std::move(filter_deletes(local_results, shid, vers));
+ query_results[i] = std::move(filter_deletes(local_results, shid, vers, &buffer));
if constexpr (Q::EARLY_ABORT) {
if (query_results[i].size() > 0) break;
@@ -563,8 +563,8 @@ private:
return m_buffer->append(rec, ts);
}
- static std::vector<Wrapped<R>> filter_deletes(std::vector<Wrapped<R>> &records, ShardID shid, Structure *vers) {
- if constexpr (!Q::SKIP_DELETE_FILTER) {
+ static std::vector<Wrapped<R>> filter_deletes(std::vector<Wrapped<R>> &records, ShardID shid, Structure *vers, BufView *bview) {
+ if constexpr (Q::SKIP_DELETE_FILTER) {
return records;
}
@@ -602,6 +602,12 @@ private:
//continue;
//}
+ for (size_t i=0; i<bview->get_record_count(); i++) {
+ if (bview->get(i)->is_tombstone() && bview->get(i)->rec == rec.rec) {
+ continue;
+ }
+ }
+
if (shid != INVALID_SHID) {
for (size_t lvl=0; lvl<=shid.level_idx; lvl++) {
if (vers->get_levels()[lvl]->check_tombstone(0, rec.rec)) {
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);
}