Extracted base class JsonParserBase

This commit is contained in:
Benoit Blanchon
2014-01-10 20:13:18 +01:00
parent 694840da31
commit 53d06a03ee

View File

@ -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];
}; };