[30/36] libcamera: value_node: Support looking up nested children in one operation
diff mbox series

Message ID 20260113000808.15395-31-laurent.pinchart@ideasonboard.com
State New
Headers show
Series
  • libcamera: Global configuration file improvements
Related show

Commit Message

Laurent Pinchart Jan. 13, 2026, 12:08 a.m. UTC
Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
---
 include/libcamera/internal/value_node.h |  1 +
 src/libcamera/value_node.cpp            | 23 +++++++++++++++++++++++
 2 files changed, 24 insertions(+)

Patch
diff mbox series

diff --git a/include/libcamera/internal/value_node.h b/include/libcamera/internal/value_node.h
index abb0991fd87e..da72651d2161 100644
--- a/include/libcamera/internal/value_node.h
+++ b/include/libcamera/internal/value_node.h
@@ -235,6 +235,7 @@  public:
 	bool contains(std::string_view key) const;
 	ValueNode *at(std::string_view key);
 	const ValueNode &operator[](std::string_view key) const;
+	const ValueNode &operator[](std::initializer_list<std::string_view> path) const;
 
 	ValueNode *add(std::unique_ptr<ValueNode> child);
 	ValueNode *add(std::string key, std::unique_ptr<ValueNode> child);
diff --git a/src/libcamera/value_node.cpp b/src/libcamera/value_node.cpp
index 1256adf8361d..55d5a1a29991 100644
--- a/src/libcamera/value_node.cpp
+++ b/src/libcamera/value_node.cpp
@@ -487,6 +487,29 @@  const ValueNode &ValueNode::operator[](std::string_view key) const
 	return *iter->second;
 }
 
+/**
+ * \brief Retrieve a descendant node by path
+ * \param[in] path The path
+ *
+ * This function retrieves a descendant of a ValueNode by following a \a path.
+ * The path is a list of keys that index nested dictionary nodes. If any node
+ * along the path is not a Dictionary node, an empty node is returned.
+ *
+ * \return The ValueNode corresponding to the \a path
+ */
+const ValueNode &ValueNode::operator[](std::initializer_list<std::string_view> path) const
+{
+	const ValueNode *node = this;
+
+	for (const auto part : path) {
+		node = &(*node)[part];
+		if (!*node)
+			return empty;
+	}
+
+	return *node;
+}
+
 /**
  * \brief Add a child node to a list
  * \param[in] child The child node