out = GetValue();
}
+void TokenStreamReader::ReadNumber(double &n) {
+ n = GetDouble();
+}
+
void TokenStreamReader::ReadNumber(float &n) {
n = GetFloat();
}
Skip(Token::BRACKET_CLOSE);
}
+void TokenStreamReader::ReadVec(glm::dvec2 &v) {
+ Skip(Token::BRACKET_OPEN);
+ ReadNumber(v.x);
+ Skip(Token::COMMA);
+ ReadNumber(v.y);
+ Skip(Token::BRACKET_CLOSE);
+}
+
+void TokenStreamReader::ReadVec(glm::dvec3 &v) {
+ Skip(Token::BRACKET_OPEN);
+ ReadNumber(v.x);
+ Skip(Token::COMMA);
+ ReadNumber(v.y);
+ Skip(Token::COMMA);
+ ReadNumber(v.z);
+ Skip(Token::BRACKET_CLOSE);
+}
+
+void TokenStreamReader::ReadVec(glm::dvec4 &v) {
+ Skip(Token::BRACKET_OPEN);
+ ReadNumber(v.x);
+ Skip(Token::COMMA);
+ ReadNumber(v.y);
+ Skip(Token::COMMA);
+ ReadNumber(v.z);
+ Skip(Token::COMMA);
+ ReadNumber(v.w);
+ Skip(Token::BRACKET_CLOSE);
+}
+
void TokenStreamReader::ReadVec(glm::ivec2 &v) {
Skip(Token::BRACKET_OPEN);
ReadNumber(v.x);
Skip(Token::BRACKET_CLOSE);
}
+void TokenStreamReader::ReadQuat(glm::dquat &q) {
+ Skip(Token::BRACKET_OPEN);
+ ReadNumber(q.w);
+ Skip(Token::COMMA);
+ ReadNumber(q.x);
+ Skip(Token::COMMA);
+ ReadNumber(q.y);
+ Skip(Token::COMMA);
+ ReadNumber(q.z);
+ Skip(Token::BRACKET_CLOSE);
+}
+
bool TokenStreamReader::GetBool() {
Next();
}
}
+double TokenStreamReader::GetDouble() {
+ Next();
+ return AsDouble();
+}
+
+double TokenStreamReader::AsDouble() const {
+ Assert(Token::NUMBER);
+ return stod(GetValue());
+}
+
float TokenStreamReader::GetFloat() {
Next();
return AsFloat();