mirror of
https://github.com/bblanchon/ArduinoJson.git
synced 2025-07-17 04:22:18 +02:00
Parse doubles
This commit is contained in:
@ -1,6 +1,6 @@
|
|||||||
#include "JsonParser.h"
|
#include "JsonParser.h"
|
||||||
#include "../JsonBuffer.h"
|
#include "../JsonBuffer.h"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h> // for strtol, strtod
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
bool JsonParser::isEnd()
|
bool JsonParser::isEnd()
|
||||||
@ -26,15 +26,28 @@ bool JsonParser::isLong()
|
|||||||
while (isdigit(*ptr))
|
while (isdigit(*ptr))
|
||||||
ptr++;
|
ptr++;
|
||||||
|
|
||||||
// same position => 0 digits => not a long
|
// same position => 0 digits => not a number
|
||||||
if (ptr == _ptr)
|
if (ptr == _ptr)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// stopped on a decimal separator => not a long but a double
|
// stopped on a decimal separator => not a long but a double
|
||||||
if (*ptr == '.')
|
return *ptr != '.';
|
||||||
|
}
|
||||||
|
|
||||||
|
bool JsonParser::isDouble()
|
||||||
|
{
|
||||||
|
char* ptr = _ptr;
|
||||||
|
|
||||||
|
// skip all digits
|
||||||
|
while (isdigit(*ptr))
|
||||||
|
ptr++;
|
||||||
|
|
||||||
|
// same position => 0 digits => not a number
|
||||||
|
if (ptr == _ptr)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
// stopped on a decimal separator => ok it's a double
|
||||||
|
return *ptr == '.';
|
||||||
}
|
}
|
||||||
|
|
||||||
bool JsonParser::isSpace()
|
bool JsonParser::isSpace()
|
||||||
@ -65,7 +78,10 @@ JsonNode* JsonParser::parseAnything()
|
|||||||
return parseArray();
|
return parseArray();
|
||||||
|
|
||||||
if (isLong())
|
if (isLong())
|
||||||
return parseLong();
|
return parseLong();
|
||||||
|
|
||||||
|
if (isDouble())
|
||||||
|
return parseDouble();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -98,15 +114,22 @@ JsonNode* JsonParser::parseArray()
|
|||||||
|
|
||||||
skipOneChar(); // skip the ','
|
skipOneChar(); // skip the ','
|
||||||
}
|
}
|
||||||
|
|
||||||
return node;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
JsonNode* JsonParser::parseLong()
|
JsonNode* JsonParser::parseLong()
|
||||||
{
|
{
|
||||||
long value = strtol(_ptr, &_ptr, 10);
|
long value = strtol(_ptr, &_ptr, 10);
|
||||||
|
|
||||||
JsonNode* node = _buffer->createNode();
|
return _buffer->createLongNode(value);
|
||||||
node->setAsLong(value);
|
}
|
||||||
return node;
|
|
||||||
}
|
JsonNode *JsonParser::parseDouble()
|
||||||
|
{
|
||||||
|
double value = strtod(_ptr, &_ptr);
|
||||||
|
|
||||||
|
int decimals = 0;
|
||||||
|
while(_ptr[1-decimals] != '.')
|
||||||
|
decimals++;
|
||||||
|
|
||||||
|
return _buffer->createDoubleNode(value, decimals);
|
||||||
|
}
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
#include "JsonNode.h"
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
class JsonNode;
|
class JsonNode;
|
||||||
@ -22,6 +24,7 @@ private:
|
|||||||
inline bool isArrayStart();
|
inline bool isArrayStart();
|
||||||
inline bool isArrayStop();
|
inline bool isArrayStop();
|
||||||
inline bool isLong();
|
inline bool isLong();
|
||||||
|
inline bool isDouble();
|
||||||
inline bool isSpace();
|
inline bool isSpace();
|
||||||
inline bool isComma();
|
inline bool isComma();
|
||||||
|
|
||||||
@ -30,4 +33,6 @@ private:
|
|||||||
|
|
||||||
inline JsonNode* parseArray();
|
inline JsonNode* parseArray();
|
||||||
inline JsonNode* parseLong();
|
inline JsonNode* parseLong();
|
||||||
|
|
||||||
|
JsonNode *parseDouble();
|
||||||
};
|
};
|
@ -23,4 +23,44 @@ JsonArray JsonBuffer::parseArray(char* json)
|
|||||||
{
|
{
|
||||||
JsonParser parser(this, json);
|
JsonParser parser(this, json);
|
||||||
return JsonArray(parser.parseAnything());
|
return JsonArray(parser.parseAnything());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
JsonNode *JsonBuffer::createArrayNode()
|
||||||
|
{
|
||||||
|
JsonNode* node = createNode();
|
||||||
|
|
||||||
|
if (node)
|
||||||
|
node->setAsArray(this);
|
||||||
|
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonNode *JsonBuffer::createObjectNode()
|
||||||
|
{
|
||||||
|
JsonNode* node = createNode();
|
||||||
|
|
||||||
|
if (node)
|
||||||
|
node->setAsObject(this);
|
||||||
|
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonNode *JsonBuffer::createLongNode(long value)
|
||||||
|
{
|
||||||
|
JsonNode* node = createNode();
|
||||||
|
|
||||||
|
if (node)
|
||||||
|
node->setAsLong(value);
|
||||||
|
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
JsonNode *JsonBuffer::createDoubleNode(double value, int decimals)
|
||||||
|
{
|
||||||
|
JsonNode* node = createNode();
|
||||||
|
|
||||||
|
if (node)
|
||||||
|
node->setAsDouble(value, decimals);
|
||||||
|
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
@ -16,16 +16,12 @@ public:
|
|||||||
|
|
||||||
JsonArray createArray()
|
JsonArray createArray()
|
||||||
{
|
{
|
||||||
JsonNode* node = createNode();
|
return JsonArray(createArrayNode());
|
||||||
if (node) node->setAsArray(this);
|
|
||||||
return JsonArray(node);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
JsonObject createObject()
|
JsonObject createObject()
|
||||||
{
|
{
|
||||||
JsonNode* node = createNode();
|
return JsonObject(createObjectNode());
|
||||||
if (node) node->setAsObject(this);
|
|
||||||
return JsonObject(node);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
JsonValue createValue();
|
JsonValue createValue();
|
||||||
@ -37,5 +33,10 @@ protected:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
JsonNode* createNode();
|
JsonNode* createNode();
|
||||||
|
|
||||||
|
JsonNode* createArrayNode();
|
||||||
|
JsonNode* createObjectNode();
|
||||||
|
JsonNode* createLongNode(long value);
|
||||||
|
JsonNode *createDoubleNode(double value, int decimals);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -115,4 +115,23 @@ TEST_F(JsonArray_Parser_Tests, TwoIntegers)
|
|||||||
sizeMustBe(2);
|
sizeMustBe(2);
|
||||||
firstElementMustBe(42);
|
firstElementMustBe(42);
|
||||||
secondElementMustBe(84);
|
secondElementMustBe(84);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(JsonArray_Parser_Tests, OneDouble)
|
||||||
|
{
|
||||||
|
whenInputIs("[4.2]");
|
||||||
|
|
||||||
|
parseMustSucceed();
|
||||||
|
sizeMustBe(1);
|
||||||
|
firstElementMustBe(4.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(JsonArray_Parser_Tests, TwoDoubles)
|
||||||
|
{
|
||||||
|
whenInputIs("[4.2,8.4]");
|
||||||
|
|
||||||
|
parseMustSucceed();
|
||||||
|
sizeMustBe(2);
|
||||||
|
firstElementMustBe(4.2);
|
||||||
|
secondElementMustBe(8.4);
|
||||||
}
|
}
|
Reference in New Issue
Block a user