20 KiB
ArduinoJson: change log
v6.6.0-beta (2018-11-13)
- Removed
JsonArray::is<T>(i)andJsonArray::set(i,v) - Removed
JsonObject::is<T>(k)andJsonObject::set(k,v) - Replaced
T JsonArray::get<T>(i)withJsonVariant JsonArray::get(i) - Replaced
T JsonObject::get<T>(k)withJsonVariant JsonObject::get(k) - Added
JSON_STRING_SIZE() - Replacing or removing a value now releases the memory
- Added
DeserializationError::code()to be used in switch statements (issue #846)
v6.5.0-beta (2018-10-13)
- Added implicit conversion from
JsonArrayandJsonObjecttoJsonVariant - Allow mixed configuration in compilation units (issue #809)
- Fixed object keys not being duplicated
JsonPair::key()now returns aJsonKey- Increased the default capacity of
DynamicJsonDocument - Fixed
JsonVariant::is<String>()(closes #763) - Added
JsonArrayConst,JsonObjectConst, andJsonVariantConst - Added copy-constructor and copy-assignment-operator for
JsonDocument(issue #827)
v6.4.0-beta (2018-09-11)
- Copy
JsonArrayandJsonObject, instead of storing pointers (issue #780) - Added
JsonVariant::to<JsonArray>()andJsonVariant::to<JsonObject>()
v6.3.0-beta (2018-08-31)
- Implemented reference semantics for
JsonVariant - Replaced
JsonPair'skeyandvaluewithkey()andvalue() - Fixed
serializeJson(obj[key], dst)(issue #794)
BREAKING CHANGES
JsonVariant
JsonVariantnow has a semantic similar toJsonObjectandJsonArray. It's a reference to a value stored in theJsonDocument. As a consequence, aJsonVariantcannot be used as a standalone variable anymore.Old code:
JsonVariant myValue = 42;New code:
DynamicJsonDocument doc; JsonVariant myValue = doc.to<JsonVariant>(); myValue.set(42);JsonPair
Old code:
for(JsonPair p : myObject) { Serial.println(p.key); Serial.println(p.value.as<int>()); }New code:
for(JsonPair p : myObject) { Serial.println(p.key()); Serial.println(p.value().as<int>()); }CAUTION: the key is now read only!
v6.2.3-beta (2018-07-19)
- Fixed exception when using Flash strings as object keys (issue #784)
v6.2.2-beta (2018-07-18)
- Fixed
invalid application of 'sizeof' to incomplete type '__FlashStringHelper'(issue #783) - Fixed
char[]not duplicated when passed toJsonVariant::operator[]
v6.2.1-beta (2018-07-17)
- Fixed
JsonObjectnot inserting keys of typeString(issue #782)
v6.2.0-beta (2018-07-12)
- Disabled lazy number deserialization (issue #772)
- Fixed
JsonVariant::is<int>()that returned true for empty strings - Improved float serialization when
-fsingle-precision-constantis used - Renamed function
RawJson()toserialized() serializeMsgPack()now supports values marked withserialized()
BREAKING CHANGES
Non quoted strings
Non quoted strings are now forbidden in values, but they are still allowed in keys. For example,
{key:"value"}is accepted, but{key:value}is not.Preformatted values
Old code:
object["values"] = RawJson("[1,2,3,4]");New code:
object["values"] = serialized("[1,2,3,4]");
v6.1.0-beta (2018-07-02)
- Return
JsonArrayandJsonObjectby value instead of reference (issue #309) - Replaced
success()withisNull()
BREAKING CHANGES
Old code:
JsonObject& obj = doc.to<JsonObject>(); JsonArray& arr = obj.createNestedArray("key"); if (!arr.success()) { Serial.println("Not enough memory"); return; }New code:
JsonObject obj = doc.to<JsonObject>(); JsonArray arr = obj.createNestedArray("key"); if (arr.isNull()) { Serial.println("Not enough memory"); return; }
v6.0.1-beta (2018-06-11)
- Fixed conflicts with
isnan()andisinf()macros (issue #752)
v6.0.0-beta (2018-06-07)
- Added
DynamicJsonDocumentandStaticJsonDocument - Added
deserializeJson() - Added
serializeJson()andserializeJsonPretty() - Added
measureJson()andmeasureJsonPretty() - Added
serializeMsgPack(),deserializeMsgPack()andmeasureMsgPack()(issue #358) - Added example
MsgPackParser.ino(issue #358) - Added support for non zero-terminated strings (issue #704)
- Removed
JsonBuffer::parseArray(),parseObject()andparse() - Removed
JsonBuffer::createArray()andcreateObject() - Removed
printTo()andprettyPrintTo() - Removed
measureLength()andmeasurePrettyLength() - Removed all deprecated features
BREAKING CHANGES
Deserialization
Old code:
DynamicJsonBuffer jb; JsonObject& obj = jb.parseObject(json); if (obj.success()) { }New code:
DynamicJsonDocument doc; DeserializationError error = deserializeJson(doc, json); if (error) { } JsonObject& obj = doc.as<JsonObject>();Serialization
Old code:
DynamicJsonBuffer jb; JsonObject& obj = jb.createObject(); obj["key"] = "value"; obj.printTo(Serial);New code:
DynamicJsonDocument obj; JsonObject& obj = doc.to<JsonObject>(); obj["key"] = "value"; serializeJson(doc, Serial);
v5.13.2
- Fixed
JsonBuffer::parse()not respecting nesting limit correctly (issue #693) - Fixed inconsistencies in nesting level counting (PR #695 from Zhenyu Wu)
- Fixed null values that could be pass to
strcmp()(PR #745 from Mike Karlesky) - Added macros
ARDUINOJSON_VERSION,ARDUINOJSON_VERSION_MAJOR...
v5.13.1
- Fixed
JsonVariant::operator|(int)that returned the default value if the variant contained a double (issue #675) - Allowed non-quoted key to contain underscores (issue #665)
v5.13.0
- Changed the rules of string duplication (issue #658)
RawJson()accepts any kind of string and obeys to the same rules for duplication- Changed the return type of
strdup()toconst char*to prevent double duplication - Marked
strdup()as deprecated
New rules for string duplication
type duplication const char* no char* noyesString yes std::string yes const __FlashStringHelper* yes These new rules make
JsonBuffer::strdup()useless.
v5.12.0
- Added
JsonVariant::operator|to return a default value (see below) - Added a clear error message when compiled as C instead of C++ (issue #629)
- Added detection of MPLAB XC compiler (issue #629)
- Added detection of Keil ARM Compiler (issue #629)
- Added an example that shows how to save and load a configuration file
- Reworked all other examples
How to use the new feature?
If you have a block like this:
const char* ssid = root["ssid"]; if (!ssid) ssid = "default ssid";You can simplify like that:
const char* ssid = root["ssid"] | "default ssid";
v5.11.2
- Fixed
DynamicJsonBuffer::clear()not resetting allocation size (issue #561) - Fixed incorrect rounding for float values (issue #588)
v5.11.1
- Removed dependency on
PGM_Pas Particle 0.6.2 doesn't define it (issue #546) - Fixed warning "dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing]"
- Fixed warning "floating constant exceeds range of 'float' [-Woverflow]" (issue #544)
- Fixed warning "this statement may fall through" [-Wimplicit-fallthrough=] (issue #539)
- Removed
ARDUINOJSON_DOUBLE_IS_64BITSas it became useless. - Fixed too many decimals places in float serialization (issue #543)
v5.11.0
- Made
JsonBuffernon-copyable (PR #524 by @luisrayas3) - Added
StaticJsonBuffer::clear() - Added
DynamicJsonBuffer::clear()
v5.10.1
- Fixed IntelliSense errors in Visual Micro (issue #483)
- Fixed compilation in IAR Embedded Workbench (issue #515)
- Fixed reading "true" as a float (issue #516)
- Added
ARDUINOJSON_DOUBLE_IS_64BITS - Added
ARDUINOJSON_EMBEDDED_MODE
v5.10.0
- Removed configurable number of decimal places (issues #288, #427 and #506)
- Changed exponentiation thresholds to
1e7and1e-5(issues #288, #427 and #506) JsonVariant::is<double>()now returnstruefor integers- Fixed error
IsBaseOf is not a member of ArduinoJson::TypeTraits(issue #495) - Fixed error
forming reference to reference(issue #495)
BREAKING CHANGES ⚠️
Old syntax New syntax double_with_n_digits(3.14, 2)3.14float_with_n_digits(3.14, 2)3.14fobj.set("key", 3.14, 2)obj["key"] = 3.14arr.add(3.14, 2)arr.add(3.14)
Input Old output New output 3.141593.143.1415942.042.00420.00.000
Expression Old result New result JsonVariant(42).is<int>()truetrueJsonVariant(42).is<float>()falsetrueJsonVariant(42).is<double>()falsetrue
v5.9.0
- Added
JsonArray::remove(iterator)(issue #479) - Added
JsonObject::remove(iterator) - Renamed
JsonArray::removeAt(size_t)intoremove(size_t) - Renamed folder
include/tosrc/ - Fixed warnings
floating constant exceeds range of floatandfloating constant truncated to zero(issue #483) - Removed
Printclass and convertedprintTo()to a template method (issue #276) - Removed example
IndentedPrintExample.ino - Now compatible with Particle 0.6.1, thanks to Jacob Nite (issue #294 and PR #461 by @foodbag)
v5.8.4
- Added custom implementation of
strtod()(issue #453) - Added custom implementation of
strtol()(issue #465) charis now treated as an integral type (issue #337, #370)
v5.8.3
- Fixed an access violation in
DynamicJsonBufferwhen memory allocation fails (issue #433) - Added operators
==and!=for twoJsonVariants (issue #436) - Fixed
JsonVariant::operator[const FlashStringHelper*](issue #441)
v5.8.2
- Fixed parsing of comments (issue #421)
- Fixed ignored
Streamtimeout (issue #422) - Made sure we don't read more that necessary (issue #422)
- Fixed error when the key of a
JsonObjectis achar[](issue #423) - Reduced code size when using
constreferences - Fixed error with string of type
unsigned char*(issue #428) - Added
deprecatedattribute onasArray(),asObject()andasString()(issue #420)
v5.8.1
- Fixed error when assigning a
volatile intto aJsonVariant(issue #415) - Fixed errors with Variable Length Arrays (issue #416)
- Fixed error when both
ARDUINOJSON_ENABLE_STD_STREAMandARDUINOJSON_ENABLE_ARDUINO_STREAMare set to1 - Fixed error "Stream does not name a type" (issue #412)
v5.8.0
- Added operator
==to compareJsonVariantand strings (issue #402) - Added support for
Stream(issue #300) - Reduced memory consumption by not duplicating spaces and comments
BREAKING CHANGES ⚠️
JsonBuffer::parseObject()andJsonBuffer::parseArray()have been pulled down to the derived classesDynamicJsonBufferandStaticJsonBufferBase.This means that if you have code like:
void myFunction(JsonBuffer& jsonBuffer);you need to replace it with one of the following:
void myFunction(DynamicJsonBuffer& jsonBuffer); void myFunction(StaticJsonBufferBase& jsonBuffer); template<typename TJsonBuffer> void myFunction(TJsonBuffer& jsonBuffer);
v5.7.3
- Added an
printTo(char[N])andprettyPrintTo(char[N])(issue #292) - Added ability to set a nested value like this:
root["A"]["B"] = "C"(issue #352) - Renamed
*.ippto*Impl.hppbecause they were ignored by Arduino IDE (issue #396)
v5.7.2
- Made PROGMEM available on more platforms (issue #381)
- Fixed PROGMEM causing an exception on ESP8266 (issue #383)
v5.7.1
- Added support for PROGMEM (issue #76)
- Fixed compilation error when index is not an
int(issue #381)
v5.7.0
- Templatized all functions using
Stringorstd::string - Removed
ArduinoJson::String - Removed
JsonVariant::defaultValue<T>() - Removed non-template
JsonObject::get()andJsonArray.get() - Fixed support for
StringSumHelper(issue #184) - Replaced
ARDUINOJSON_USE_ARDUINO_STRINGbyARDUINOJSON_ENABLE_STD_STRINGandARDUINOJSON_ENABLE_ARDUINO_STRING(issue #378) - Added example
StringExample.inoto show whereStringcan be used - Increased default nesting limit to 50 when compiled for a computer (issue #349)
BREAKING CHANGES ⚠️
The non-template functions
JsonObject::get()andJsonArray.get()have been removed. This means that you need to explicitely tell the type you expect in return.Old code:
#define ARDUINOJSON_USE_ARDUINO_STRING 0 JsonVariant value1 = myObject.get("myKey"); JsonVariant value2 = myArray.get(0);New code:
#define ARDUINOJSON_ENABLE_ARDUINO_STRING 0 #define ARDUINOJSON_ENABLE_STD_STRING 1 JsonVariant value1 = myObject.get<JsonVariant>("myKey"); JsonVariant value2 = myArray.get<JsonVariant>(0);
v5.6.7
- Fixed
array[idx].as<JsonVariant>()andobject[key].as<JsonVariant>() - Fixed return value of
JsonObject::set()(issue #350) - Fixed undefined behavior in
PrettyfierandPrint(issue #354) - Fixed parser that incorrectly rejected floats containing a
+(issue #349)
v5.6.6
- Fixed
-Wparentheseswarning introduced in v5.6.5 (PR #335 by @nuket) - Added
.mbedignorefor ARM mbdeb (PR #334 by @nuket) - Fixed
JsonVariant::success()which didn't propagateJsonArray::success()norJsonObject::success()(issue #342).
v5.6.5
as<char*>()now returnstruewhen input isnull(issue #330)
v5.6.4
- Fixed error in float serialization (issue #324)
v5.6.3
- Improved speed of float serialization (about twice faster)
- Added
as<JsonArray>()as a synonym foras<JsonArray&>()... (issue #291) - Fixed
call of overloaded isinf(double&) is ambiguous(issue #284)
v5.6.2
- Fixed build when another lib does
#undef isnan(issue #284)
v5.6.1
- Added missing
#pragma once(issue #310)
v5.6.0
- ArduinoJson is now a header-only library (issue #199)
v5.5.1
- Fixed compilation error with Intel Galileo (issue #299)
v5.5.0
- Added
JsonVariant::success()(issue #279) - Renamed
JsonVariant::invalid<T>()toJsonVariant::defaultValue<T>()
v5.4.0
- Changed
::StringtoArduinoJson::String(issue #275) - Changed
::PrinttoArduinoJson::Printtoo
v5.3.0
- Added custom implementation of
ftoa(issues #266, #267, #269 and #270) - Added
JsonVariant JsonBuffer::parse()(issue #265) - Fixed
unsigned longprinted assigned long(issue #170)
v5.2.0
- Added
JsonVariant::as<char*>()as a synonym forJsonVariant::as<const char*>()(issue #257) - Added example
JsonHttpClient(issue #256) - Added
JsonArray::copyTo()andJsonArray::copyFrom()(issue #254) - Added
RawJson()to insert pregenerated JSON portions (issue #259)
v5.1.1
- Removed
Stringduplication when one replaces a value in aJsonObject(PR #232 by @ulion)
v5.1.0
- Added support of
long long(issue #171) - Moved all build settings to
ArduinoJson/Configuration.hpp
BREAKING CHANGE ⚠️
If you defined
ARDUINOJSON_ENABLE_STD_STREAM, you now need to define it to1.
v5.0.8
- Made the library compatible with PlatformIO (issue #181)
- Fixed
JsonVariant::is<bool>()that was incorrectly returning false (issue #214)
v5.0.7
- Made library easier to use from a CMake project: simply
add_subdirectory(ArduinoJson/src) - Changed
Stringto be atypedefofstd::string(issues #142 and #161)
BREAKING CHANGES ⚠️
JsonVariant(true).as<String>()now returns"true"instead of"1"JsonVariant(false).as<String>()now returns"false"instead of"0"
v5.0.6
- Added parameter to
DynamicJsonBufferconstructor to set initial size (issue #152) - Fixed warning about library category in Arduino 1.6.6 (issue #147)
- Examples: Added a loop to wait for serial port to be ready (issue #156)
v5.0.5
- Added overload
JsonObjectSuscript::set(value, decimals)(issue #143) - Use
floatinstead ofdoubleto reduce the size ofJsonVariant(issue #134)
v5.0.4
- Fixed ambiguous overload with
JsonArraySubscriptandJsonObjectSubscript(issue #122)
v5.0.3
- Fixed
printTo(String)which wrote numbers instead of strings (issue #120) - Fixed return type of
JsonArray::is<T>()and some others (issue #121)
v5.0.2
- Fixed segmentation fault in
parseObject(String)andparseArray(String), when theStaticJsonBufferis too small to hold a copy of the string - Fixed Clang warning "register specifier is deprecated" (issue #102)
- Fixed GCC warning "declaration shadows a member" (issue #103)
- Fixed memory alignment, which made ESP8266 crash (issue #104)
- Fixed compilation on Visual Studio 2010 and 2012 (issue #107)
v5.0.1
- Fixed compilation with Arduino 1.0.6 (issue #99)
v5.0.0
- Added support of
Stringclass (issues #55, #56, #70, #77) - Added
JsonBuffer::strdup()to make a copy of a string (issues #10, #57) - Implicitly call
strdup()forStringbut not forchar*(issues #84, #87) - Added support of non standard JSON input (issue #44)
- Added support of comments in JSON input (issue #88)
- Added implicit cast between numerical types (issues #64, #69, #93)
- Added ability to read number values as string (issue #90)
- Redesigned
JsonVariantto leverage converting constructors instead of assignment operators (issue #66) - Switched to new the library layout (requires Arduino 1.0.6 or above)
BREAKING CHANGES ⚠️
JsonObject::add()was renamed toset()JsonArray::at()andJsonObject::at()were renamed toget()- Number of digits of floating point value are now set with
double_with_n_digits()
Personal note about the String class:
Support of the String class has been added to the library because many people use it in their programs.
However, you should not see this as an invitation to use the String class.
The String class is bad because it uses dynamic memory allocation.
Compared to static allocation, it compiles to a bigger, slower program, and is less predictable.
You certainly don't want that in an embedded environment!