aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/include/uhdlib/rfnoc/node_accessor.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/include/uhdlib/rfnoc/node_accessor.hpp')
-rw-r--r--host/lib/include/uhdlib/rfnoc/node_accessor.hpp84
1 files changed, 84 insertions, 0 deletions
diff --git a/host/lib/include/uhdlib/rfnoc/node_accessor.hpp b/host/lib/include/uhdlib/rfnoc/node_accessor.hpp
new file mode 100644
index 000000000..26e6a5607
--- /dev/null
+++ b/host/lib/include/uhdlib/rfnoc/node_accessor.hpp
@@ -0,0 +1,84 @@
+//
+// Copyright 2019 Ettus Research, a National Instruments Brand
+//
+// SPDX-License-Identifier: GPL-3.0-or-later
+//
+
+#ifndef INCLUDED_LIBUHD_NODE_ACCESSOR_HPP
+#define INCLUDED_LIBUHD_NODE_ACCESSOR_HPP
+
+#include <uhd/rfnoc/node.hpp>
+#include <functional>
+
+namespace uhd { namespace rfnoc {
+
+//! Special class which may access nodes
+//
+// For the sake of property resolution, we require access to certain private
+// members of nodes. Instead of giving the entire graph
+// access to everything, we create this accessor class which is not available
+// in the public API.
+class node_accessor_t
+{
+public:
+ using prop_ptrs_t = node_t::prop_ptrs_t;
+
+ /*! Initializes the properties of a node. See node_t::init_props() for
+ * details.
+ */
+ void init_props(node_t* node)
+ {
+ node->init_props();
+ }
+
+ /*! Does a local resolution of properties on \p node.
+ *
+ * See node_t::resolve_props for details.
+ */
+ void resolve_props(node_t* node)
+ {
+ node->resolve_props();
+ }
+
+ /*! Returns a filtered list of properties.
+ *
+ * The return list contains all properties that match a given predicate.
+ */
+ template <typename PredicateType>
+ node_t::prop_ptrs_t filter_props(node_t* node, PredicateType&& predicate)
+ {
+ return node->filter_props(std::forward<PredicateType>(predicate));
+ }
+
+ /*! Mark all properties on this node as clean
+ *
+ * See node_t::clean_props() for details.
+ */
+ void clean_props(node_t* node)
+ {
+ node->clean_props();
+ }
+
+ /*! Set a resolver callback for the node
+ *
+ * See node_t::set_resolve_all_callback() for details.
+ */
+ void set_resolve_all_callback(node_t* node, node_t::resolve_callback_t&& resolver)
+ {
+ node->set_resolve_all_callback(std::move(resolver));
+ }
+
+ /*! Forward an edge property to \p dst_node
+ *
+ * See node_t::forward_edge_property() for details.
+ */
+ void forward_edge_property(node_t* dst_node, property_base_t* incoming_prop)
+ {
+ dst_node->forward_edge_property(incoming_prop);
+ }
+};
+
+
+}} /* namespace uhd::rfnoc */
+
+#endif /* INCLUDED_LIBUHD_NODE_ACCESSOR_HPP */