node.h 2.58 KB
Newer Older
beder's avatar
beder committed
1
2
3
4
5
6
7
8
9
#ifndef VALUE_DETAIL_NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
#define VALUE_DETAIL_NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66

#if defined(_MSC_VER) || (defined(__GNUC__) && (__GNUC__ == 3 && __GNUC_MINOR__ >= 4) || (__GNUC__ >= 4)) // GCC supports "pragma once" correctly since 3.4
#pragma once
#endif


#include "yaml-cpp/dll.h"
beder's avatar
beder committed
10
#include "yaml-cpp/value/type.h"
beder's avatar
beder committed
11
#include "yaml-cpp/value/ptr.h"
12
#include "yaml-cpp/value/detail/node_ref.h"
13
#include <boost/utility.hpp>
beder's avatar
beder committed
14
15
16
17
18

namespace YAML
{
	namespace detail
	{
19
		class node: private boost::noncopyable
beder's avatar
beder committed
20
21
		{
		public:
22
			node(): m_pRef(new node_ref) {}
23

beder's avatar
beder committed
24
			bool is(const node& rhs) const { return m_pRef == rhs.m_pRef; }
beder's avatar
beder committed
25
26
			const node_ref *ref() const { return m_pRef.get(); }
			
27
28
29
			ValueType::value type() const { return m_pRef->type(); }
			
			const std::string& scalar() const { return m_pRef->scalar(); }
30
			
31
32
			void set_ref(const node& rhs) { m_pRef = rhs.m_pRef; }
			void set_data(const node& rhs) { m_pRef->set_data(*rhs.m_pRef); }
33
				
34
35
36
			void set_type(ValueType::value type) { m_pRef->set_type(type); }
			void set_null() { m_pRef->set_null(); }
			void set_scalar(const std::string& scalar) { m_pRef->set_scalar(scalar); }
beder's avatar
beder committed
37
38
39
40

			// size/iterator
			std::size_t size() const { return m_pRef->size(); }
			
41
42
			const_node_iterator begin() const { return static_cast<const node_ref&>(*m_pRef).begin(); }
			node_iterator begin() { return m_pRef->begin(); }
beder's avatar
beder committed
43
			
44
45
			const_node_iterator end() const { return static_cast<const node_ref&>(*m_pRef).end(); }
			node_iterator end() { return m_pRef->end(); }
beder's avatar
beder committed
46
47

			// sequence
beder's avatar
beder committed
48
			void append(node& node, shared_memory_holder pMemory) { m_pRef->append(node, pMemory); }
49
50
51
			void insert(node& key, node& value, shared_memory_holder pMemory) {
				m_pRef->insert(key, value, pMemory);
			}
beder's avatar
beder committed
52

53
			// indexing
54
55
			template<typename Key> node& get(const Key& key, shared_memory_holder pMemory) const { return static_cast<const node_ref&>(*m_pRef).get(key, pMemory); }
			template<typename Key> node& get(const Key& key, shared_memory_holder pMemory) { return m_pRef->get(key, pMemory); }
56
			template<typename Key> bool remove(const Key& key, shared_memory_holder pMemory) { return m_pRef->remove(key, pMemory); }
beder's avatar
beder committed
57
			
58
59
60
			node& get(node& key, shared_memory_holder pMemory) const { return static_cast<const node_ref&>(*m_pRef).get(key, pMemory); }
			node& get(node& key, shared_memory_holder pMemory) { return m_pRef->get(key, pMemory); }
			bool remove(node& key, shared_memory_holder pMemory) { return m_pRef->remove(key, pMemory); }
61

beder's avatar
beder committed
62
		private:
63
			shared_node_ref m_pRef;
beder's avatar
beder committed
64
65
66
67
68
		};
	}
}

#endif // VALUE_DETAIL_NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66