Coverage Report

Created: 2026-02-14 06:38

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/yaml-cpp/include/yaml-cpp/node/detail/node.h
Line
Count
Source
1
#ifndef NODE_DETAIL_NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
2
#define NODE_DETAIL_NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
3
4
#if defined(_MSC_VER) ||                                            \
5
    (defined(__GNUC__) && (__GNUC__ == 3 && __GNUC_MINOR__ >= 4) || \
6
     (__GNUC__ >= 4))  // GCC supports "pragma once" correctly since 3.4
7
#pragma once
8
#endif
9
10
#include "yaml-cpp/dll.h"
11
#include "yaml-cpp/emitterstyle.h"
12
#include "yaml-cpp/node/detail/node_ref.h"
13
#include "yaml-cpp/node/ptr.h"
14
#include "yaml-cpp/node/type.h"
15
#include <set>
16
#include <atomic>
17
18
namespace YAML {
19
namespace detail {
20
class node {
21
 private:
22
  struct less {
23
0
    bool operator ()(const node* l, const node* r) const {return l->m_index < r->m_index;}
24
  };
25
26
 public:
27
2.82M
  node() : m_pRef(new node_ref), m_dependencies{}, m_index{} {}
28
  node(const node&) = delete;
29
  node& operator=(const node&) = delete;
30
31
0
  bool is(const node& rhs) const { return m_pRef == rhs.m_pRef; }
32
0
  const node_ref* ref() const { return m_pRef.get(); }
33
34
10.3M
  bool is_defined() const { return m_pRef->is_defined(); }
35
0
  const Mark& mark() const { return m_pRef->mark(); }
36
6.99M
  NodeType::value type() const { return m_pRef->type(); }
37
38
0
  const std::string& scalar() const { return m_pRef->scalar(); }
39
0
  const std::string& tag() const { return m_pRef->tag(); }
40
0
  EmitterStyle::value style() const { return m_pRef->style(); }
41
42
  template <typename T>
43
  bool equals(const T& rhs, shared_memory_holder pMemory);
44
  bool equals(const char* rhs, shared_memory_holder pMemory);
45
46
6.26M
  void mark_defined() {
47
6.26M
    if (is_defined())
48
3.44M
      return;
49
50
2.82M
    m_pRef->mark_defined();
51
2.82M
    for (node* dependency : m_dependencies)
52
0
      dependency->mark_defined();
53
2.82M
    m_dependencies.clear();
54
2.82M
  }
55
56
2.40M
  void add_dependency(node& rhs) {
57
2.40M
    if (is_defined())
58
2.40M
      rhs.mark_defined();
59
0
    else
60
0
      m_dependencies.insert(&rhs);
61
2.40M
  }
62
63
0
  void set_ref(const node& rhs) {
64
0
    if (rhs.is_defined())
65
0
      mark_defined();
66
0
    m_pRef = rhs.m_pRef;
67
0
  }
68
0
  void set_data(const node& rhs) {
69
0
    if (rhs.is_defined())
70
0
      mark_defined();
71
0
    m_pRef->set_data(*rhs.m_pRef);
72
0
  }
73
74
2.82M
  void set_mark(const Mark& mark) { m_pRef->set_mark(mark); }
75
76
393k
  void set_type(NodeType::value type) {
77
393k
    if (type != NodeType::Undefined)
78
393k
      mark_defined();
79
393k
    m_pRef->set_type(type);
80
393k
  }
81
2.17M
  void set_null() {
82
2.17M
    mark_defined();
83
2.17M
    m_pRef->set_null();
84
2.17M
  }
85
249k
  void set_scalar(const std::string& scalar) {
86
249k
    mark_defined();
87
249k
    m_pRef->set_scalar(scalar);
88
249k
  }
89
642k
  void set_tag(const std::string& tag) {
90
642k
    mark_defined();
91
642k
    m_pRef->set_tag(tag);
92
642k
  }
93
94
  // style
95
393k
  void set_style(EmitterStyle::value style) {
96
393k
    mark_defined();
97
393k
    m_pRef->set_style(style);
98
393k
  }
99
100
  // size/iterator
101
0
  std::size_t size() const { return m_pRef->size(); }
102
103
0
  const_node_iterator begin() const {
104
0
    return static_cast<const node_ref&>(*m_pRef).begin();
105
0
  }
106
0
  node_iterator begin() { return m_pRef->begin(); }
107
108
0
  const_node_iterator end() const {
109
0
    return static_cast<const node_ref&>(*m_pRef).end();
110
0
  }
111
0
  node_iterator end() { return m_pRef->end(); }
112
113
  // sequence
114
720k
  void push_back(node& input, shared_memory_holder pMemory) {
115
720k
    m_pRef->push_back(input, pMemory);
116
720k
    input.add_dependency(*this);
117
720k
    m_index = m_amount.fetch_add(1);
118
720k
  }
119
844k
  void insert(node& key, node& value, shared_memory_holder pMemory) {
120
844k
    m_pRef->insert(key, value, pMemory);
121
844k
    key.add_dependency(*this);
122
844k
    value.add_dependency(*this);
123
844k
  }
124
125
  // indexing
126
  template <typename Key>
127
  node* get(const Key& key, shared_memory_holder pMemory) const {
128
    // NOTE: this returns a non-const node so that the top-level Node can wrap
129
    // it, and returns a pointer so that it can be nullptr (if there is no such
130
    // key).
131
    return static_cast<const node_ref&>(*m_pRef).get(key, pMemory);
132
  }
133
  template <typename Key>
134
  node& get(const Key& key, shared_memory_holder pMemory) {
135
    node& value = m_pRef->get(key, pMemory);
136
    value.add_dependency(*this);
137
    return value;
138
  }
139
  template <typename Key>
140
  bool remove(const Key& key, shared_memory_holder pMemory) {
141
    return m_pRef->remove(key, pMemory);
142
  }
143
144
0
  node* get(node& key, shared_memory_holder pMemory) const {
145
0
    // NOTE: this returns a non-const node so that the top-level Node can wrap
146
0
    // it, and returns a pointer so that it can be nullptr (if there is no such
147
0
    // key).
148
0
    return static_cast<const node_ref&>(*m_pRef).get(key, pMemory);
149
0
  }
150
0
  node& get(node& key, shared_memory_holder pMemory) {
151
0
    node& value = m_pRef->get(key, pMemory);
152
0
    key.add_dependency(*this);
153
0
    value.add_dependency(*this);
154
0
    return value;
155
0
  }
156
0
  bool remove(node& key, shared_memory_holder pMemory) {
157
0
    return m_pRef->remove(key, pMemory);
158
0
  }
159
160
  // map
161
  template <typename Key, typename Value>
162
  void force_insert(const Key& key, const Value& value,
163
                    shared_memory_holder pMemory) {
164
    m_pRef->force_insert(key, value, pMemory);
165
  }
166
167
 private:
168
  shared_node_ref m_pRef;
169
  using nodes = std::set<node*, less>;
170
  nodes m_dependencies;
171
  size_t m_index;
172
  static YAML_CPP_API std::atomic<size_t> m_amount;
173
};
174
}  // namespace detail
175
}  // namespace YAML
176
177
#endif  // NODE_DETAIL_NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66