node.h 3.36 KB
Newer Older
1
2
#pragma once

3
4
5
6
#ifndef NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
#define NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66


7
#include "conversion.h"
8
9
#include "exceptions.h"
#include "iterator.h"
10
#include "mark.h"
11
#include "noncopyable.h"
12
#include "parserstate.h"
13
#include <iostream>
14
15
16
#include <string>
#include <vector>
#include <map>
Jesse Beder's avatar
Jesse Beder committed
17
#include <memory>
18
19
20
21
22

namespace YAML
{
	class Content;
	class Scanner;
23
	class Emitter;
24
25
26

	enum CONTENT_TYPE { CT_NONE, CT_SCALAR, CT_SEQUENCE, CT_MAP };

27
	class Node: private noncopyable
28
29
30
31
32
33
	{
	public:
		Node();
		~Node();

		void Clear();
Jesse Beder's avatar
Jesse Beder committed
34
		std::auto_ptr<Node> Clone() const;
35
36
37
38
		void Parse(Scanner *pScanner, const ParserState& state);

		CONTENT_TYPE GetType() const;

39
		// file location of start of this node
40
		const Mark GetMark() const { return m_mark; }
41

42
43
44
		// accessors
		Iterator begin() const;
		Iterator end() const;
45
		std::size_t size() const;
46

47
		// extraction of scalars
48
49
50
		bool GetScalar(std::string& s) const;

		// we can specialize this for other values
51
		template <typename T>
52
		bool Read(T& value) const;
53

54
55
		template <typename T>
		const T Read() const;
56
57
58
		
		template <typename T>
		operator T() const;
59

60
61
		template <typename T>
		friend void operator >> (const Node& node, T& value);
62

63
		// retrieval for maps and sequences
64
		template <typename T>
65
		const Node *FindValue(const T& key) const;
66

67
68
		template <typename T>
		const Node& operator [] (const T& key) const;
69
70
71
		
		// specific to maps
		const Node *FindValue(const char *key) const;
72
		const Node& operator [] (const char *key) const;
73

74
75
76
77
78
		// for anchors/aliases
		const Node *Identity() const { return m_pIdentity; }
		bool IsAlias() const { return m_alias; }
		bool IsReferenced() const { return m_referenced; }

79
80
		// emitting
		friend Emitter& operator << (Emitter& out, const Node& node);
81
82
83
84
85

		// ordering
		int Compare(const Node& rhs) const;
		friend bool operator < (const Node& n1, const Node& n2);

Jesse Beder's avatar
Jesse Beder committed
86
	private:
87
88
89
90
		// helper for sequences
		template <typename, bool> friend struct _FindFromNodeAtIndex;
		const Node *FindAtIndex(std::size_t i) const;
		
91
92
93
		// helper for maps
		template <typename T>
		const Node& GetValue(const T& key) const;
94
95
96

		template <typename T>
		const Node *FindValueForKey(const T& key) const;
Jesse Beder's avatar
Jesse Beder committed
97
98
99
		
		// helper for cloning
		Node(const Mark& mark, const std::string& anchor, const std::string& tag, const Content *pContent);
100

101
		// helpers for parsing
102
103
104
105
106
107
		void ParseHeader(Scanner *pScanner, const ParserState& state);
		void ParseTag(Scanner *pScanner, const ParserState& state);
		void ParseAnchor(Scanner *pScanner, const ParserState& state);
		void ParseAlias(Scanner *pScanner, const ParserState& state);

	private:
108
		Mark m_mark;
109
110
111
		std::string m_anchor, m_tag;
		Content *m_pContent;
		bool m_alias;
112
113
		const Node *m_pIdentity;
		mutable bool m_referenced;
114
	};
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
	
	// comparisons with auto-conversion
	template <typename T>
	bool operator == (const T& value, const Node& node);
	
	template <typename T>
	bool operator == (const Node& node, const T& value);
	
	template <typename T>
	bool operator != (const T& value, const Node& node);
	
	template <typename T>
	bool operator != (const Node& node, const T& value);
	
	bool operator == (const char *value, const Node& node);
	bool operator == (const Node& node, const char *value);
	bool operator != (const char *value, const Node& node);
	bool operator != (const Node& node, const char *value);
133
}
134
135

#include "nodeimpl.h"
136
137

#endif // NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66