Moved implementation in a .cpp file

This commit is contained in:
Benoit Blanchon
2014-01-10 20:19:58 +01:00
parent 53d06a03ee
commit a80eca9e91
2 changed files with 61 additions and 41 deletions

44
ArduinoJsonParser.cpp Normal file
View File

@ -0,0 +1,44 @@
/*
* malloc-free JSON parser for Arduino
* Benoit Blanchon 2014
* MIT License
*/
#include "ArduinoJsonParser.h"
bool JsonParserBase::parseTokens(char* jsonString)
{
buffer = jsonString;
if (JSMN_SUCCESS != jsmn_parse(&parser, jsonString, tokens, tokenCount))
return false;
// Add null termination to each token
for (int i = 0; i < tokenCount; i++)
{
buffer[tokens[i].end] = 0;
}
return true;
}
char* JsonParserBase::getValueByKey(char* name)
{
// Scan each keys, every two other token
// (skip index 0, because it's the whole json object)
for (int i = 1; i < tokenCount; i += 2)
{
// Early break if we reach the last token
if (i >= parser.toknext) break;
// Get key token string
char* key = buffer + tokens[i].start;
// Compare with desired name
if (strcmp(name, key) == 0)
{
return buffer + tokens[i + 1].start;
}
}
}

View File

@ -12,55 +12,25 @@
class JsonParserBase
{
public:
JsonParserBase()
{
jsmn_init(&parser);
}
protected:
bool parseTokens(char* jsonString, jsmntok_t* tokens, int tokenCount)
JsonParserBase(jsmntok_t* tokens, int tokenCount)
{
buffer = jsonString;
this->tokenCount = tokenCount;
this->tokens = tokens;
if (JSMN_SUCCESS != jsmn_parse(&parser, jsonString, tokens, tokenCount))
return false;
// Add null termination to each token
for (int i = 0; i < tokenCount; i++)
{
buffer[tokens[i].end] = 0;
}
return true;
}
char* getValueByKey(char* name, jsmntok_t* tokens, int tokenCount)
{
// Scan each keys, every two other token
// (skip index 0, because it's the whole json object)
for (int i = 1; i < tokenCount; i += 2)
{
// Early break if we reach the last token
if (i >= parser.toknext) break;
// Get key token string
char* key = buffer + tokens[i].start;
// Compare with desired name
if (strcmp(name, key) == 0)
{
return buffer + tokens[i + 1].start;
}
}
jsmn_init(&parser);
}
bool parseTokens(char* jsonString);
char* getValueByKey(char* name);
private:
char* buffer;
jsmn_parser parser;
int tokenCount;
jsmntok_t* tokens;
};
template <int N>
@ -68,14 +38,20 @@ class ArduinoJsonParser : JsonParserBase
{
public:
ArduinoJsonParser()
: JsonParserBase(tokens, N * 2 + 1)
{
}
bool parse(char* json)
{
return parseTokens(json, tokens, N * 2 + 1);
return parseTokens(json);
}
char* getValue(char* name)
{
return getValueByKey(name, tokens, N * 2 + 1);
return getValueByKey(name);
}
private: