forked from bblanchon/ArduinoJson
Extracted base class JsonParserBase
This commit is contained in:
@ -10,22 +10,21 @@
|
|||||||
#include <Arduino.h>
|
#include <Arduino.h>
|
||||||
#include "utility/jsmn.h"
|
#include "utility/jsmn.h"
|
||||||
|
|
||||||
template <int N>
|
class JsonParserBase
|
||||||
class ArduinoJsonParser
|
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
ArduinoJsonParser()
|
JsonParserBase()
|
||||||
{
|
{
|
||||||
jsmn_init(&parser);
|
jsmn_init(&parser);
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean parse(char* jsonString)
|
protected:
|
||||||
|
|
||||||
|
bool parseTokens(char* jsonString, jsmntok_t* tokens, int tokenCount)
|
||||||
{
|
{
|
||||||
buffer = jsonString;
|
buffer = jsonString;
|
||||||
|
|
||||||
int tokenCount = sizeof(tokens) / sizeof(tokens[0]);
|
|
||||||
|
|
||||||
if (JSMN_SUCCESS != jsmn_parse(&parser, jsonString, tokens, tokenCount))
|
if (JSMN_SUCCESS != jsmn_parse(&parser, jsonString, tokens, tokenCount))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -38,11 +37,11 @@ public:
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
char* getValue(char* name)
|
char* getValueByKey(char* name, jsmntok_t* tokens, int tokenCount)
|
||||||
{
|
{
|
||||||
// Scan each keys, every two other token
|
// Scan each keys, every two other token
|
||||||
// (skip index 0, because it's the whole json object)
|
// (skip index 0, because it's the whole json object)
|
||||||
for (int i = 1; i < 2 * N; i += 2)
|
for (int i = 1; i < tokenCount; i += 2)
|
||||||
{
|
{
|
||||||
// Early break if we reach the last token
|
// Early break if we reach the last token
|
||||||
if (i >= parser.toknext) break;
|
if (i >= parser.toknext) break;
|
||||||
@ -62,6 +61,25 @@ private:
|
|||||||
|
|
||||||
char* buffer;
|
char* buffer;
|
||||||
jsmn_parser parser;
|
jsmn_parser parser;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <int N>
|
||||||
|
class ArduinoJsonParser : JsonParserBase
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
bool parse(char* json)
|
||||||
|
{
|
||||||
|
return parseTokens(json, tokens, N * 2 + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
char* getValue(char* name)
|
||||||
|
{
|
||||||
|
return getValueByKey(name, tokens, N * 2 + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
jsmntok_t tokens[N * 2 + 1];
|
jsmntok_t tokens[N * 2 + 1];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user