scalar.cpp 1.84 KB
Newer Older
1
#include "crt.h"
2
#include "scalar.h"
3
4
#include "scanner.h"
#include "token.h"
5
#include "exceptions.h"
Jesse Beder's avatar
Jesse Beder committed
6
#include "node.h"
7
#include <sstream>
8
9
10

namespace YAML
{
11
	Scalar::Scalar()
12
13
14
15
16
17
	{
	}

	Scalar::~Scalar()
	{
	}
18

19
	void Scalar::Parse(Scanner *pScanner, const ParserState& state)
20
	{
21
		Token& token = pScanner->peek();
22
		m_data = token.value;
23
		pScanner->pop();
24
25
	}

26
	void Scalar::Write(std::ostream& out, int indent, bool startedLine, bool onlyOneCharOnLine)
27
	{
28
29
30
31
32
33
34
35
36
37
38
		out << "\"";
		for(unsigned i=0;i<m_data.size();i++) {
			switch(m_data[i]) {
				case '\\': out << "\\\\"; break;
				case '\t': out << "\\t"; break;
				case '\n': out << "\\n"; break;
				case '\r': out << "\\r"; break;
				default: out << m_data[i]; break;
			}
		}
		out << "\"\n";
39
	}
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92

	void Scalar::Read(std::string& s)
	{
		s = m_data;
	}

	void Scalar::Read(int& i)
	{
		std::stringstream data(m_data);
		data >> i;
		if(!data)
			throw InvalidScalar();
	}

	void Scalar::Read(unsigned& u)
	{
		std::stringstream data(m_data);
		data >> u;
		if(!data)
			throw InvalidScalar();
	}

	void Scalar::Read(long& l)
	{
		std::stringstream data(m_data);
		data >> l;
		if(!data)
			throw InvalidScalar();
	}
	
	void Scalar::Read(float& f)
	{
		std::stringstream data(m_data);
		data >> f;
		if(!data)
			throw InvalidScalar();
	}
	
	void Scalar::Read(double& d)
	{
		std::stringstream data(m_data);
		data >> d;
		if(!data)
			throw InvalidScalar();
	}

	void Scalar::Read(char& c)
	{
		std::stringstream data(m_data);
		data >> c;
		if(!data)
			throw InvalidScalar();
	}
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107

	int Scalar::Compare(Content *pContent)
	{
		return -pContent->Compare(this);
	}

	int Scalar::Compare(Scalar *pScalar)
	{
		if(m_data < pScalar->m_data)
			return -1;
		else if(m_data > pScalar->m_data)
			return 1;
		else
			return 0;
	}
108
}