ArduinoJsonParser.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*
  2. * malloc-free JSON parser for Arduino
  3. * Benoit Blanchon 2014
  4. * MIT License
  5. */
  6. #include "ArduinoJsonParser.h"
  7. int JsonObjectBase::getNestedTokenCounts(int tokenIndex)
  8. {
  9. int count = 0;
  10. for (int i = 0; i < tokens[tokenIndex].size; i++)
  11. {
  12. count += 1 + getNestedTokenCounts(tokenIndex + 1 + i);
  13. }
  14. return count;
  15. }
  16. bool JsonParserBase::parse(char* jsonString)
  17. {
  18. buffer = jsonString;
  19. if (JSMN_SUCCESS != jsmn_parse(&parser, jsonString, tokens, maxTokenCount))
  20. return false;
  21. // Add null termination to each token
  22. for (int i = 1; i < parser.toknext; i++)
  23. {
  24. buffer[tokens[i].end] = 0;
  25. }
  26. return true;
  27. }
  28. char* JsonHashTable::getString(char* name)
  29. {
  30. // skip first token, it's the whole object
  31. int currentToken = 1;
  32. // Scan each keys
  33. for (int i = 0; i < tokens[0].size / 2 ; i++)
  34. {
  35. // Get key token string
  36. char* key = json + tokens[currentToken].start;
  37. // Compare with desired name
  38. if (strcmp(name, key) == 0)
  39. {
  40. return json + tokens[currentToken + 1].start;
  41. }
  42. // move forward: key + value + nested tokens
  43. currentToken += 2 + getNestedTokenCounts(currentToken + 1);
  44. }
  45. return NULL;
  46. }
  47. /*
  48. char* JsonParserBase::getValueByIndex(int index)
  49. {
  50. for (int i = 1; i < parser.toknext; i++)
  51. {
  52. if (index == 0)
  53. {
  54. return buffer + tokens[i].start;
  55. }
  56. // skip nested objects
  57. i += getNestedTokenCounts(i);
  58. index--;
  59. }
  60. return NULL;
  61. }
  62. int JsonParserBase::getArraySize()
  63. {
  64. int size = 0;
  65. for (int i = 1; i < parser.toknext; i++)
  66. {
  67. // skip nested objects
  68. i += getNestedTokenCounts(i);
  69. size++;
  70. }
  71. return size;
  72. }
  73. */