summaryrefslogtreecommitdiffstats
path: root/include/framework/interface
diff options
context:
space:
mode:
authorDouglas Rumbaugh <dbr4@psu.edu>2023-10-30 17:15:05 -0400
committerDouglas Rumbaugh <dbr4@psu.edu>2023-10-30 17:15:05 -0400
commitd2279e1b96d352a0af1d425dcaaf93e8a26a8d52 (patch)
tree4e8df98339ff5578deb8f8be46b9f6c3cc34cef4 /include/framework/interface
parent8ce1cb0eef7d5631f0f7788804845ddc8296ac6f (diff)
downloaddynamic-extension-d2279e1b96d352a0af1d425dcaaf93e8a26a8d52.tar.gz
General Comment + Consistency updates
Diffstat (limited to 'include/framework/interface')
-rw-r--r--include/framework/interface/Query.h34
-rw-r--r--include/framework/interface/Record.h5
-rw-r--r--include/framework/interface/Scheduler.h4
-rw-r--r--include/framework/interface/Shard.h20
4 files changed, 39 insertions, 24 deletions
diff --git a/include/framework/interface/Query.h b/include/framework/interface/Query.h
index 9b1d2d6..21cadcb 100644
--- a/include/framework/interface/Query.h
+++ b/include/framework/interface/Query.h
@@ -1,7 +1,7 @@
/*
- * include/framework/QueryInterface.h
+ * include/framework/interface/Query.h
*
- * Copyright (C) 2023 Douglas Rumbaugh <drumbaugh@psu.edu>
+ * Copyright (C) 2023 Douglas B. Rumbaugh <drumbaugh@psu.edu>
*
* All rights reserved. Published under the Modified BSD License.
*
@@ -10,25 +10,29 @@
#include <vector>
#include <concepts>
+
#include "util/types.h"
+// FIXME: The interface is not completely specified yet, as it is pending
+// determining a good way to handle additional template arguments
+// to get the Shard and Record types into play
template <typename Q>
concept QueryInterface = requires(Q q, void *p, std::vector<void*> &s) {
-/*
- {q.get_query_state(p, p)} -> std::convertible_to<void*>;
- {q.get_buffer_query_state(p, p)};
- {q.query(p, p)};
- {q.buffer_query(p, p)};
- {q.merge()};
- {q.delete_query_state(p)};
-*/
- {Q::EARLY_ABORT} -> std::convertible_to<bool>;
- {Q::SKIP_DELETE_FILTER} -> std::convertible_to<bool>;
- //{Q::get_query_state(p, p)} -> std::convertible_to<void*>;
- //{Q::get_buffer_query_state(p, p)} -> std::convertible_to<void*>;
+
+ /*
+ {Q::get_query_state(p, p)} -> std::convertible_to<void*>;
+ {Q::get_buffer_query_state(p, p)} -> std::convertible_to<void *>;
+ */
{Q::process_query_states(p, s, s)};
+ /*
+ {Q::query(s, p, p)} -> std::convertible_to<std::vector<Wrapped<R>>>;
+ {Q::buffer_query(p, p)} -> std::convertible_to<std::vector<Wrapped<R>>>;
+ {Q::merge(rv, p)} -> std::convertible_to<std::vector<R>>;
+ */
{Q::delete_query_state(std::declval<void*>())} -> std::same_as<void>;
- {Q::delete_buffer_query_state(p)};
+ {Q::delete_buffer_query_state(std::declval<void*>())} -> std::same_as<void>;
+ {Q::EARLY_ABORT} -> std::convertible_to<bool>;
+ {Q::SKIP_DELETE_FILTER} -> std::convertible_to<bool>;
};
diff --git a/include/framework/interface/Record.h b/include/framework/interface/Record.h
index 1ef1984..bf495df 100644
--- a/include/framework/interface/Record.h
+++ b/include/framework/interface/Record.h
@@ -1,11 +1,12 @@
/*
- * include/framework/RecordInterface.h
+ * include/framework/interface/Record.h
*
* Copyright (C) 2023 Douglas Rumbaugh <drumbaugh@psu.edu>
- * Dong Xie <dongx@psu.edu>
*
* All rights reserved. Published under the Modified BSD License.
*
+ * FIXME: the record implementations could probably be broken out into
+ * different files, leaving only the interface here
*/
#pragma once
diff --git a/include/framework/interface/Scheduler.h b/include/framework/interface/Scheduler.h
index e8ffd08..63581d2 100644
--- a/include/framework/interface/Scheduler.h
+++ b/include/framework/interface/Scheduler.h
@@ -1,7 +1,7 @@
/*
- * include/framework/QueryInterface.h
+ * include/framework/interface/Scheduler.h
*
- * Copyright (C) 2023 Douglas Rumbaugh <drumbaugh@psu.edu>
+ * Copyright (C) 2023 Douglas B. Rumbaugh <drumbaugh@psu.edu>
*
* All rights reserved. Published under the Modified BSD License.
*
diff --git a/include/framework/interface/Shard.h b/include/framework/interface/Shard.h
index ea58b2a..d3a6cf8 100644
--- a/include/framework/interface/Shard.h
+++ b/include/framework/interface/Shard.h
@@ -1,7 +1,7 @@
/*
- * include/framework/ShardInterface.h
+ * include/framework/interface/Shard.h
*
- * Copyright (C) 2023 Douglas Rumbaugh <drumbaugh@psu.edu>
+ * Copyright (C) 2023 Douglas B. Rumbaugh <drumbaugh@psu.edu>
*
* All rights reserved. Published under the Modified BSD License.
*
@@ -15,12 +15,22 @@
namespace de {
-//template <template<typename> typename S, typename R>
+// FIXME: The interface is not completely specified yet, as it is pending
+// determining a good way to handle additional template arguments
+// to get the Record type into play
template <typename S>
-concept ShardInterface = requires(S s, void *p, bool b) {
- //{s.point_lookup(r, b) } -> std::same_as<R*>;
+concept ShardInterface = requires(S s, S **spp, void *p, bool b, size_t i) {
+ {S(spp, i)};
+ /*
+ {S(mutable buffer)}
+ {s.point_lookup(r, b) } -> std::convertible_to<void*>
+ */
+ {s.get_data()} -> std::convertible_to<void*>;
+
{s.get_record_count()} -> std::convertible_to<size_t>;
+ {s.get_tombstone_count()} -> std::convertible_to<size_t>;
{s.get_memory_usage()} -> std::convertible_to<size_t>;
+ {s.get_aux_memory_usage()} -> std::convertible_to<size_t>;
};
}