17 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	ArduinoJson: change log
HEAD
- Disabled lazy number deserialization (issue #772)
- Improved float serialization when -fsingle-precision-constantis used
- Renamed function RawJson()toserialized()
- serializeMsgPack()now supports values marked with- serialized()
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
- 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
- Fixed conflicts with isnan()andisinf()macros (issue #752)
v6.0.0-beta
- 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 returns- truefor 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 returns- truewhen input is- null(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!