mirror of
https://github.com/jbeder/yaml-cpp.git
synced 2025-09-09 12:41:17 +00:00
Merge
This commit is contained in:
@@ -393,6 +393,7 @@ inline const Node Node::operator[](const Node& key) const {
|
|||||||
throw InvalidNode();
|
throw InvalidNode();
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
key.EnsureNodeExists();
|
key.EnsureNodeExists();
|
||||||
|
m_pMemory->merge(*key.m_pMemory);
|
||||||
detail::node& value =
|
detail::node& value =
|
||||||
static_cast<const detail::node&>(*m_pNode).get(*key.m_pNode, m_pMemory);
|
static_cast<const detail::node&>(*m_pNode).get(*key.m_pNode, m_pMemory);
|
||||||
return Node(value, m_pMemory);
|
return Node(value, m_pMemory);
|
||||||
@@ -403,6 +404,7 @@ inline Node Node::operator[](const Node& key) {
|
|||||||
throw InvalidNode();
|
throw InvalidNode();
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
key.EnsureNodeExists();
|
key.EnsureNodeExists();
|
||||||
|
m_pMemory->merge(*key.m_pMemory);
|
||||||
detail::node& value = m_pNode->get(*key.m_pNode, m_pMemory);
|
detail::node& value = m_pNode->get(*key.m_pNode, m_pMemory);
|
||||||
return Node(value, m_pMemory);
|
return Node(value, m_pMemory);
|
||||||
}
|
}
|
||||||
|
@@ -261,6 +261,17 @@ TEST(NodeTest, CloneNull) {
|
|||||||
EXPECT_EQ(NodeType::Null, clone.Type());
|
EXPECT_EQ(NodeType::Null, clone.Type());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(NodeTest, KeyNodeExitsScope) {
|
||||||
|
Node node;
|
||||||
|
{
|
||||||
|
Node temp("Hello, world");
|
||||||
|
node[temp] = 0;
|
||||||
|
}
|
||||||
|
for (const auto& kv : node) {
|
||||||
|
(void)kv;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
TEST(NodeTest, DefaultNodeStyle) {
|
TEST(NodeTest, DefaultNodeStyle) {
|
||||||
Node node;
|
Node node;
|
||||||
EXPECT_EQ(EmitterStyle::Default, node.Style());
|
EXPECT_EQ(EmitterStyle::Default, node.Style());
|
||||||
|
Reference in New Issue
Block a user