Bladeren bron

Removed `JsonArray::is<T>(i)` and `JsonArray::set(i,v)`
Removed `JsonObject::is<T>(k)` and `JsonObject::set(k,v)`
Replaced `T JsonArray::get<T>(i)` with `JsonVariant JsonArray::get(i)`
Replaced `T JsonObject::get<T>(k)` with `JsonVariant JsonObject::get(k)`

Benoit Blanchon 7 jaren geleden
bovenliggende
commit
1a4515c0b9

+ 8 - 0
CHANGELOG.md

@@ -1,6 +1,14 @@
 ArduinoJson: change log
 =======================
 
+HEAD
+----
+
+* Removed `JsonArray::is<T>(i)` and `JsonArray::set(i,v)`
+* Removed `JsonObject::is<T>(k)` and `JsonObject::set(k,v)`
+* Replaced `T JsonArray::get<T>(i)` with `JsonVariant JsonArray::get(i)`
+* Replaced `T JsonObject::get<T>(k)` with `JsonVariant JsonObject::get(k)`
+
 v6.5.0-beta (2018-10-13)
 -----------
 

+ 2 - 32
src/ArduinoJson/JsonArray.hpp

@@ -191,15 +191,8 @@ class JsonArray : public JsonArrayProxy<JsonArrayData>, public Visitable {
   }
 
   // Gets the value at the specified index.
-  template <typename T>
-  FORCE_INLINE typename JsonVariantAs<T>::type get(size_t index) const {
-    return get_impl(index).as<T>();
-  }
-
-  // Check the type of the value at specified index.
-  template <typename T>
-  FORCE_INLINE bool is(size_t index) const {
-    return get_impl(index).is<T>();
+  FORCE_INLINE JsonVariant get(size_t index) const {
+    return JsonVariant(_memoryPool, arrayGet(_data, index));
   }
 
   // Removes element at specified position.
@@ -212,25 +205,6 @@ class JsonArray : public JsonArrayProxy<JsonArrayData>, public Visitable {
     arrayRemove(_data, index);
   }
 
-  // Sets the value at specified index.
-  //
-  // bool add(size_t index, const TValue&);
-  // TValue = bool, long, int, short, float, double, serialized, JsonVariant,
-  //          std::string, String, JsonArray, JsonObject
-  template <typename T>
-  FORCE_INLINE bool set(size_t index, const T& value) const {
-    if (!_data) return false;
-    return get_impl(index).set(value);
-  }
-  //
-  // bool add(size_t index, TValue);
-  // TValue = char*, const char*, const FlashStringHelper*
-  template <typename T>
-  FORCE_INLINE bool set(size_t index, T* value) const {
-    if (!_data) return false;
-    return get_impl(index).set(value);
-  }
-
   template <typename Visitor>
   FORCE_INLINE void accept(Visitor& visitor) const {
     JsonArrayConst(_data).accept(visitor);
@@ -242,10 +216,6 @@ class JsonArray : public JsonArrayProxy<JsonArrayData>, public Visitable {
     return add().set(value);
   }
 
-  FORCE_INLINE JsonVariant get_impl(size_t index) const {
-    return JsonVariant(_memoryPool, arrayGet(_data, index));
-  }
-
   MemoryPool* _memoryPool;
 };
 }  // namespace ARDUINOJSON_NAMESPACE

+ 1 - 1
src/ArduinoJson/JsonArraySubscript.hpp

@@ -90,7 +90,7 @@ class JsonArraySubscript : public JsonVariantBase<JsonArraySubscript>,
 
  private:
   FORCE_INLINE JsonVariant get_impl() const {
-    return _array.get<JsonVariant>(_index);
+    return _array.get(_index);
   }
 
   JsonArray _array;

+ 12 - 69
src/ArduinoJson/JsonObject.hpp

@@ -80,18 +80,18 @@ class JsonObjectConst : public JsonObjectProxy<const JsonObjectData>,
   // TKey = const std::string&, const String&
   // TValue = bool, char, long, int, short, float, double,
   //          std::string, String, JsonArrayConst, JsonObjectConst
-  template <typename TValue, typename TKey>
-  FORCE_INLINE typename JsonVariantAs<TValue>::type get(const TKey& key) const {
-    return get_impl(makeString(key)).template as<TValue>();
+  template <typename TKey>
+  FORCE_INLINE JsonVariantConst get(const TKey& key) const {
+    return get_impl(makeString(key));
   }
   //
   // TValue get<TValue>(TKey) const;
   // TKey = char*, const char*, const FlashStringHelper*
   // TValue = bool, char, long, int, short, float, double,
   //          std::string, String, JsonArrayConst, JsonObjectConst
-  template <typename TValue, typename TKey>
-  FORCE_INLINE typename JsonVariantAs<TValue>::type get(TKey* key) const {
-    return get_impl(makeString(key)).template as<TValue>();
+  template <typename TKey>
+  FORCE_INLINE JsonVariantConst get(TKey* key) const {
+    return get_impl(makeString(key));
   }
 
   //
@@ -191,39 +191,18 @@ class JsonObject : public JsonObjectProxy<JsonObjectData>, public Visitable {
   // TKey = const std::string&, const String&
   // TValue = bool, char, long, int, short, float, double,
   //          std::string, String, JsonArray, JsonObject
-  template <typename TValue, typename TKey>
-  FORCE_INLINE typename JsonVariantAs<TValue>::type get(const TKey& key) const {
-    return get_impl(makeString(key)).template as<TValue>();
+  template <typename TKey>
+  FORCE_INLINE JsonVariant get(const TKey& key) const {
+    return get_impl(makeString(key));
   }
   //
   // TValue get<TValue>(TKey) const;
   // TKey = char*, const char*, const FlashStringHelper*
   // TValue = bool, char, long, int, short, float, double,
   //          std::string, String, JsonArray, JsonObject
-  template <typename TValue, typename TKey>
-  FORCE_INLINE typename JsonVariantAs<TValue>::type get(TKey* key) const {
-    return get_impl(makeString(key)).template as<TValue>();
-  }
-
-  // Checks the type of the value associated with the specified key.
-  //
-  //
-  // bool is<TValue>(TKey) const;
-  // TKey = const std::string&, const String&
-  // TValue = bool, char, long, int, short, float, double,
-  //          std::string, String, JsonArray, JsonObject
-  template <typename TValue, typename TKey>
-  FORCE_INLINE bool is(const TKey& key) const {
-    return get_impl(makeString(key)).template is<TValue>();
-  }
-  //
-  // bool is<TValue>(TKey) const;
-  // TKey = char*, const char*, const FlashStringHelper*
-  // TValue = bool, char, long, int, short, float, double,
-  //          std::string, String, JsonArray, JsonObject
-  template <typename TValue, typename TKey>
-  FORCE_INLINE bool is(TKey* key) const {
-    return get_impl(makeString(key)).template is<TValue>();
+  template <typename TKey>
+  FORCE_INLINE JsonVariant get(TKey* key) const {
+    return get_impl(makeString(key));
   }
 
   // Gets or sets the value associated with the specified key.
@@ -267,42 +246,6 @@ class JsonObject : public JsonObjectProxy<JsonObjectData>, public Visitable {
     remove_impl(makeString(key));
   }
 
-  // Sets the specified key with the specified value.
-  //
-  // bool set(TKey, TValue);
-  // TKey = const std::string&, const String&
-  // TValue = bool, long, int, short, float, double, serialized, JsonVariant,
-  //          std::string, String, JsonArray, JsonObject
-  template <typename TValue, typename TKey>
-  FORCE_INLINE bool set(const TKey& key, const TValue& value) const {
-    return set(key).set(value);
-  }
-  //
-  // bool set(TKey, TValue);
-  // TKey = const std::string&, const String&
-  // TValue = char*, const char*, const FlashStringHelper*
-  template <typename TValue, typename TKey>
-  FORCE_INLINE bool set(const TKey& key, TValue* value) const {
-    return set(key).set(value);
-  }
-  //
-  // bool set(TKey, const TValue&);
-  // TKey = char*, const char*, const FlashStringHelper*
-  // TValue = bool, long, int, short, float, double, serialized, JsonVariant,
-  //          std::string, String, JsonArray, JsonObject
-  template <typename TValue, typename TKey>
-  FORCE_INLINE bool set(TKey* key, const TValue& value) const {
-    return set(key).set(value);
-  }
-  //
-  // bool set(TKey, TValue);
-  // TKey = char*, const char*, const FlashStringHelper*
-  // TValue = char*, const char*, const FlashStringHelper*
-  template <typename TValue, typename TKey>
-  FORCE_INLINE bool set(TKey* key, TValue* value) const {
-    return set(key).set(value);
-  }
-
   template <typename TKey>
   FORCE_INLINE JsonVariant set(TKey* key) const {
     return set_impl(makeString(key));

+ 1 - 1
src/ArduinoJson/JsonObjectSubscript.hpp

@@ -99,7 +99,7 @@ class JsonObjectSubscript
 
  private:
   FORCE_INLINE JsonVariant get_impl() const {
-    return _object.get<JsonVariant>(_key);
+    return _object.get(_key);
   }
 
   FORCE_INLINE JsonVariant set_impl() const {

+ 0 - 1
test/JsonArray/CMakeLists.txt

@@ -11,7 +11,6 @@ add_executable(JsonArrayTests
 	isNull.cpp
 	iterator.cpp
 	remove.cpp
-	set.cpp
 	size.cpp
 	std_string.cpp
 	subscript.cpp

+ 0 - 115
test/JsonArray/set.cpp

@@ -1,115 +0,0 @@
-// ArduinoJson - arduinojson.org
-// Copyright Benoit Blanchon 2014-2018
-// MIT License
-
-#include <ArduinoJson.h>
-#include <catch.hpp>
-
-using namespace Catch::Matchers;
-
-TEST_CASE("JsonArray::set()") {
-  DynamicJsonDocument doc;
-  JsonArray array = doc.to<JsonArray>();
-  array.add(0);
-
-  SECTION("int") {
-    array.set(0, 123);
-    REQUIRE(123 == array[0].as<int>());
-    REQUIRE(array[0].is<int>());
-    REQUIRE_FALSE(array[0].is<bool>());
-  }
-
-  SECTION("double") {
-    array.set(0, 123.45);
-    REQUIRE(123.45 == array[0].as<double>());
-    REQUIRE(array[0].is<double>());
-    REQUIRE_FALSE(array[0].is<int>());
-  }
-
-  SECTION("bool") {
-    array.set(0, true);
-    REQUIRE(true == array[0].as<bool>());
-    REQUIRE(array[0].is<bool>());
-    REQUIRE_FALSE(array[0].is<int>());
-  }
-
-  SECTION("const char*") {
-    array.set(0, "hello");
-    REQUIRE_THAT(array[0].as<const char*>(), Equals("hello"));
-    REQUIRE(array[0].is<const char*>());
-    REQUIRE_FALSE(array[0].is<int>());
-  }
-
-#ifdef HAS_VARIABLE_LENGTH_ARRAY
-  SECTION("set()") {
-    int i = 16;
-    char vla[i];
-    strcpy(vla, "world");
-
-    array.add("hello");
-    array.set(0, vla);
-
-    REQUIRE(std::string("world") == array[0]);
-  }
-#endif
-
-  SECTION("nested array") {
-    DynamicJsonDocument doc2;
-    JsonArray arr = doc2.to<JsonArray>();
-
-    array.set(0, arr);
-
-    REQUIRE(arr == array[0].as<JsonArray>());
-    REQUIRE(array[0].is<JsonArray>());
-    REQUIRE_FALSE(array[0].is<int>());
-  }
-
-  SECTION("nested object") {
-    DynamicJsonDocument doc2;
-    JsonObject obj = doc2.to<JsonObject>();
-
-    array.set(0, obj);
-
-    REQUIRE(obj == array[0].as<JsonObject>());
-    REQUIRE(array[0].is<JsonObject>());
-    REQUIRE_FALSE(array[0].is<int>());
-  }
-
-  SECTION("array subscript") {
-    DynamicJsonDocument doc2;
-    JsonArray arr = doc2.to<JsonArray>();
-    arr.add("hello");
-
-    array.set(0, arr[0]);
-
-    REQUIRE_THAT(array[0].as<char*>(), Equals("hello"));
-  }
-
-  SECTION("object subscript") {
-    DynamicJsonDocument doc2;
-    JsonObject obj = doc2.to<JsonObject>();
-    obj["x"] = "hello";
-
-    array.set(0, obj["x"]);
-
-    REQUIRE_THAT(array[0].as<char*>(), Equals("hello"));
-  }
-
-  SECTION("should not duplicate const char*") {
-    array.set(0, "world");
-    const size_t expectedSize = JSON_ARRAY_SIZE(1);
-    REQUIRE(expectedSize == doc.memoryUsage());
-  }
-
-  SECTION("should duplicate char*") {
-    array.set(0, const_cast<char*>("world"));
-    const size_t expectedSize = JSON_ARRAY_SIZE(1) + 6;
-    REQUIRE(expectedSize == doc.memoryUsage());
-  }
-
-  SECTION("should duplicate std::string") {
-    array.set(0, std::string("world"));
-    const size_t expectedSize = JSON_ARRAY_SIZE(1) + 6;
-    REQUIRE(expectedSize == doc.memoryUsage());
-  }
-}

+ 1 - 9
test/JsonArray/size.cpp

@@ -21,15 +21,7 @@ TEST_CASE("JsonArray::size()") {
     REQUIRE(2U == array.size());
   }
 
-  SECTION("remains the same after set()") {
-    array.add("hello");
-    REQUIRE(1U == array.size());
-
-    array.set(0, "hello");
-    REQUIRE(1U == array.size());
-  }
-
-  SECTION("remains the same after assigment") {
+  SECTION("remains the same after replacing an element") {
     array.add("hello");
     REQUIRE(1U == array.size());
 

+ 0 - 8
test/JsonArray/std_string.cpp

@@ -21,14 +21,6 @@ TEST_CASE("std::string") {
     REQUIRE(std::string("hello") == array[0]);
   }
 
-  SECTION("set()") {
-    std::string value("world");
-    array.add("hello");
-    array.set(0, value);
-    eraseString(value);
-    REQUIRE(std::string("world") == array[0]);
-  }
-
   SECTION("operator[]") {
     std::string value("world");
     array.add("hello");

+ 0 - 3
test/JsonObject/CMakeLists.txt

@@ -8,13 +8,10 @@ add_executable(JsonObjectTests
 	createNestedArray.cpp
 	createNestedObject.cpp
 	equals.cpp
-	get.cpp
 	invalid.cpp
-	is.cpp
 	isNull.cpp
 	iterator.cpp
 	remove.cpp
-	set.cpp
 	size.cpp
 	std_string.cpp
 	subscript.cpp

+ 1 - 1
test/JsonObject/containsKey.cpp

@@ -8,7 +8,7 @@
 TEST_CASE("JsonObject::containsKey()") {
   DynamicJsonDocument doc;
   JsonObject obj = doc.to<JsonObject>();
-  obj.set("hello", 42);
+  obj["hello"] = 42;
 
   SECTION("returns true only if key is present") {
     REQUIRE(false == obj.containsKey("world"));

+ 0 - 37
test/JsonObject/get.cpp

@@ -1,37 +0,0 @@
-// ArduinoJson - arduinojson.org
-// Copyright Benoit Blanchon 2014-2018
-// MIT License
-
-#include <ArduinoJson.h>
-#include <catch.hpp>
-
-using namespace Catch::Matchers;
-
-TEST_CASE("JsonObject::get()") {
-  DynamicJsonDocument doc;
-  JsonObject obj = doc.to<JsonObject>();
-
-  SECTION("get<const char*>(const char*)") {
-    obj.set("hello", "world");
-    const char* value = obj.get<const char*>("hello");
-    REQUIRE_THAT(value, Equals("world"));
-  }
-
-#ifdef HAS_VARIABLE_LENGTH_ARRAY
-  SECTION("get<const char*>(VLA)") {
-    obj.set("hello", "world");
-    int i = 16;
-    char vla[i];
-    strcpy(vla, "hello");
-
-    REQUIRE(std::string("world") == obj.get<char*>(vla));
-  }
-#endif
-
-  SECTION("works on JsonObjectConst") {
-    obj.set("hello", "world");
-    const char* value =
-        static_cast<JsonObjectConst>(obj).get<const char*>("hello");
-    REQUIRE_THAT(value, Equals("world"));
-  }
-}

+ 1 - 1
test/JsonObject/invalid.cpp

@@ -15,7 +15,7 @@ TEST_CASE("JsonObject::invalid()") {
   }
 
   SECTION("AddFails") {
-    obj.set("hello", "world");
+    obj["hello"] = "world";
     REQUIRE(0 == obj.size());
   }
 

+ 0 - 28
test/JsonObject/is.cpp

@@ -1,28 +0,0 @@
-// ArduinoJson - arduinojson.org
-// Copyright Benoit Blanchon 2014-2018
-// MIT License
-
-#include <ArduinoJson.h>
-#include <catch.hpp>
-
-TEST_CASE("JsonObject::is<T>()") {
-  DynamicJsonDocument doc;
-  JsonObject obj = doc.to<JsonObject>();
-  obj["int"] = 42;
-  obj["str"] = "hello";
-
-  SECTION("is<int>(const char*)") {
-    REQUIRE(true == obj.is<int>("int"));
-    REQUIRE(false == obj.is<int>("str"));
-  }
-
-#if HAS_VARIABLE_LENGTH_ARRAY
-  SECTION("is<T>(VLA)") {
-    int i = 16;
-    char vla[i];
-    strcpy(vla, "int");
-
-    REQUIRE(true == obj.is<int>(vla));
-  }
-#endif
-}

+ 0 - 174
test/JsonObject/set.cpp

@@ -1,174 +0,0 @@
-// ArduinoJson - arduinojson.org
-// Copyright Benoit Blanchon 2014-2018
-// MIT License
-
-#include <ArduinoJson.h>
-#include <catch.hpp>
-#include <string>
-
-TEST_CASE("JsonObject::set()") {
-  DynamicJsonDocument doc;
-  JsonObject obj = doc.to<JsonObject>();
-
-  SECTION("int") {
-    obj.set("hello", 123);
-
-    REQUIRE(123 == obj["hello"].as<int>());
-    REQUIRE(obj["hello"].is<int>());
-    REQUIRE_FALSE(obj["hello"].is<bool>());
-  }
-
-  SECTION("double") {
-    obj.set("hello", 123.45);
-
-    REQUIRE(123.45 == obj["hello"].as<double>());
-    REQUIRE(obj["hello"].is<double>());
-    REQUIRE_FALSE(obj["hello"].is<bool>());
-  }
-
-  SECTION("bool") {
-    obj.set("hello", true);
-
-    REQUIRE(obj["hello"].as<bool>());
-    REQUIRE(obj["hello"].is<bool>());
-    REQUIRE_FALSE(obj["hello"].is<long>());
-  }
-
-  SECTION("const char*") {
-    obj.set("hello", "h3110");
-
-    REQUIRE(std::string("h3110") == obj["hello"].as<const char*>());
-    REQUIRE(obj["hello"].is<const char*>());
-    REQUIRE_FALSE(obj["hello"].is<long>());
-  }
-
-#ifdef HAS_VARIABLE_LENGTH_ARRAY
-  SECTION("key is a VLA") {
-    int i = 16;
-    char vla[i];
-    strcpy(vla, "hello");
-
-    obj.set(vla, "world");
-
-    REQUIRE(std::string("world") == obj["hello"]);
-  }
-
-  SECTION("value is a VLA") {
-    int i = 16;
-    char vla[i];
-    strcpy(vla, "world");
-
-    obj.set("hello", vla);
-
-    REQUIRE(std::string("world") == obj["hello"]);
-  }
-
-  SECTION("key and value are VLAs") {
-    int i = 16;
-    char vla[i];
-    strcpy(vla, "world");
-
-    obj.set(vla, vla);
-
-    REQUIRE(std::string("world") == obj["world"]);
-  }
-#endif
-
-  SECTION("nested array") {
-    DynamicJsonDocument doc2;
-    JsonArray arr = doc2.to<JsonArray>();
-
-    obj.set("hello", arr);
-
-    REQUIRE(arr == obj["hello"].as<JsonArray>());
-    REQUIRE(obj["hello"].is<JsonArray>());
-    REQUIRE_FALSE(obj["hello"].is<JsonObject>());
-  }
-
-  SECTION("nested object") {
-    DynamicJsonDocument doc2;
-    JsonObject obj2 = doc2.to<JsonObject>();
-
-    obj.set("hello", obj2);
-
-    REQUIRE(obj2 == obj["hello"].as<JsonObject>());
-    REQUIRE(obj["hello"].is<JsonObject>());
-    REQUIRE_FALSE(obj["hello"].is<JsonArray>());
-  }
-
-  SECTION("array subscript") {
-    DynamicJsonDocument doc2;
-    JsonArray arr = doc2.to<JsonArray>();
-    arr.add(42);
-
-    obj.set("a", arr[0]);
-
-    REQUIRE(42 == obj["a"]);
-  }
-
-  SECTION("object subscript") {
-    DynamicJsonDocument doc2;
-    JsonObject obj2 = doc2.to<JsonObject>();
-    obj2.set("x", 42);
-
-    obj.set("a", obj2["x"]);
-
-    REQUIRE(42 == obj["a"]);
-  }
-
-  SECTION("returns true when allocation succeeds") {
-    StaticJsonDocument<JSON_OBJECT_SIZE(1) + 15> doc2;
-    JsonObject obj2 = doc2.to<JsonObject>();
-
-    REQUIRE(true == obj2.set(std::string("hello"), std::string("world")));
-  }
-
-  SECTION("returns false when allocation fails") {
-    StaticJsonDocument<JSON_OBJECT_SIZE(1) + 10> doc2;
-    JsonObject obj2 = doc2.to<JsonObject>();
-
-    REQUIRE(false == obj2.set(std::string("hello"), std::string("world")));
-  }
-
-  SECTION("should not duplicate const char*") {
-    obj.set("hello", "world");
-    const size_t expectedSize = JSON_OBJECT_SIZE(1);
-    REQUIRE(expectedSize == doc.memoryUsage());
-  }
-
-  SECTION("should duplicate char* value") {
-    obj.set("hello", const_cast<char*>("world"));
-    const size_t expectedSize = JSON_OBJECT_SIZE(1) + 6;
-    REQUIRE(expectedSize == doc.memoryUsage());
-  }
-
-  SECTION("should duplicate char* key") {
-    obj.set(const_cast<char*>("hello"), "world");
-    const size_t expectedSize = JSON_OBJECT_SIZE(1) + 6;
-    REQUIRE(expectedSize == doc.memoryUsage());
-  }
-
-  SECTION("should duplicate char* key&value") {
-    obj.set(const_cast<char*>("hello"), const_cast<char*>("world"));
-    const size_t expectedSize = JSON_OBJECT_SIZE(1) + 12;
-    REQUIRE(expectedSize <= doc.memoryUsage());
-  }
-
-  SECTION("should duplicate std::string value") {
-    obj.set("hello", std::string("world"));
-    const size_t expectedSize = JSON_OBJECT_SIZE(1) + 6;
-    REQUIRE(expectedSize == doc.memoryUsage());
-  }
-
-  SECTION("should duplicate std::string key") {
-    obj.set(std::string("hello"), "world");
-    const size_t expectedSize = JSON_OBJECT_SIZE(1) + 6;
-    REQUIRE(expectedSize == doc.memoryUsage());
-  }
-
-  SECTION("should duplicate std::string key&value") {
-    obj.set(std::string("hello"), std::string("world"));
-    const size_t expectedSize = JSON_OBJECT_SIZE(1) + 12;
-    REQUIRE(expectedSize <= doc.memoryUsage());
-  }
-}

+ 2 - 2
test/JsonObject/size.cpp

@@ -15,12 +15,12 @@ TEST_CASE("JsonObject::size()") {
   }
 
   SECTION("increases when values are added") {
-    obj.set("hello", 42);
+    obj["hello"] = 42;
     REQUIRE(1 == obj.size());
   }
 
   SECTION("decreases when values are removed") {
-    obj.set("hello", 42);
+    obj["hello"] = 42;
     obj.remove("hello");
     REQUIRE(0 == obj.size());
   }

+ 0 - 64
test/JsonObject/std_string.cpp

@@ -31,70 +31,6 @@ TEST_CASE("std::string") {
     REQUIRE(std::string("value") == obj[std::string("key")]);
   }
 
-  SECTION("set(key)") {
-    JsonObject obj = doc.to<JsonObject>();
-    std::string key("hello");
-    obj.set(key, "world");
-    eraseString(key);
-    REQUIRE(std::string("world") == obj["hello"]);
-  }
-
-  SECTION("set(value)") {
-    JsonObject obj = doc.to<JsonObject>();
-    std::string value("world");
-    obj.set("hello", value);
-    eraseString(value);
-    REQUIRE(std::string("world") == obj["hello"]);
-  }
-
-  SECTION("set(key,value)") {
-    JsonObject obj = doc.to<JsonObject>();
-    std::string key("hello");
-    std::string value("world");
-    obj.set(key, value);
-    eraseString(key);
-    eraseString(value);
-    REQUIRE(std::string("world") == obj["hello"]);
-  }
-
-  SECTION("set(JsonArraySubscript)") {
-    JsonObject obj = doc.to<JsonObject>();
-    DynamicJsonDocument doc2;
-    JsonArray arr = doc2.to<JsonArray>();
-    arr.add("world");
-
-    obj.set(std::string("hello"), arr[0]);
-
-    REQUIRE(std::string("world") == obj["hello"]);
-  }
-
-  SECTION("set(JsonObjectSubscript)") {
-    JsonObject obj = doc.to<JsonObject>();
-    DynamicJsonDocument doc2;
-    JsonObject obj2 = doc2.to<JsonObject>();
-    obj2.set("x", "world");
-
-    obj.set(std::string("hello"), obj2["x"]);
-
-    REQUIRE(std::string("world") == obj["hello"]);
-  }
-
-  SECTION("get<T>()") {
-    char json[] = "{\"key\":\"value\"}";
-    deserializeJson(doc, json);
-    JsonObject obj = doc.as<JsonObject>();
-
-    REQUIRE(std::string("value") == obj.get<const char *>(std::string("key")));
-  }
-
-  SECTION("is<T>()") {
-    char json[] = "{\"key\":\"value\"}";
-    deserializeJson(doc, json);
-    JsonObject obj = doc.as<JsonObject>();
-
-    REQUIRE(true == obj.is<const char *>(std::string("key")));
-  }
-
   SECTION("createNestedObject()") {
     JsonObject obj = doc.to<JsonObject>();
     std::string key = "key";

+ 1 - 1
test/JsonObject/subscript.cpp

@@ -86,7 +86,7 @@ TEST_CASE("JsonObject::operator[]") {
   SECTION("object subscript") {
     DynamicJsonDocument doc2;
     JsonObject obj2 = doc2.to<JsonObject>();
-    obj2.set("x", 42);
+    obj2["x"] = 42;
 
     obj["a"] = obj2["x"];
 

+ 8 - 8
test/JsonSerializer/JsonObject.cpp

@@ -26,7 +26,7 @@ TEST_CASE("serializeJson(JsonObject)") {
 
   SECTION("TwoStrings") {
     obj["key1"] = "value1";
-    obj.set("key2", "value2");
+    obj["key2"] = "value2";
 
     check(obj, "{\"key1\":\"value1\",\"key2\":\"value2\"}");
   }
@@ -64,31 +64,31 @@ TEST_CASE("serializeJson(JsonObject)") {
 
   SECTION("TwoIntegers") {
     obj["a"] = 1;
-    obj.set("b", 2);
+    obj["b"] = 2;
     check(obj, "{\"a\":1,\"b\":2}");
   }
 
   SECTION("serialized(const char*)") {
     obj["a"] = serialized("[1,2]");
-    obj.set("b", serialized("[4,5]"));
+    obj["b"] = serialized("[4,5]");
     check(obj, "{\"a\":[1,2],\"b\":[4,5]}");
   }
 
   SECTION("Two doubles") {
     obj["a"] = 12.34;
-    obj.set("b", 56.78);
+    obj["b"] = 56.78;
     check(obj, "{\"a\":12.34,\"b\":56.78}");
   }
 
   SECTION("TwoNull") {
     obj["a"] = static_cast<char *>(0);
-    obj.set("b", static_cast<char *>(0));
+    obj["b"] = static_cast<char *>(0);
     check(obj, "{\"a\":null,\"b\":null}");
   }
 
   SECTION("TwoBooleans") {
     obj["a"] = true;
-    obj.set("b", false);
+    obj["b"] = false;
     check(obj, "{\"a\":true,\"b\":false}");
   }
 
@@ -98,7 +98,7 @@ TEST_CASE("serializeJson(JsonObject)") {
 
     obj.createNestedArray("a");
     obj["b"] = b.to<JsonArray>();
-    obj.set("c", c.to<JsonArray>());
+    obj["c"] = c.to<JsonArray>();
 
     check(obj, "{\"a\":[],\"b\":[],\"c\":[]}");
   }
@@ -109,7 +109,7 @@ TEST_CASE("serializeJson(JsonObject)") {
 
     obj.createNestedObject("a");
     obj["b"] = b.to<JsonObject>();
-    obj.set("c", c.to<JsonObject>());
+    obj["c"] = c.to<JsonObject>();
 
     check(obj, "{\"a\":{},\"b\":{},\"c\":{}}");
   }

+ 0 - 60
test/Misc/unsigned_char.cpp

@@ -110,45 +110,6 @@ TEST_CASE("unsigned char[]") {
     }
 #endif
 
-    SECTION("get()") {
-      unsigned char key[] = "hello";
-
-      DynamicJsonDocument doc;
-      deserializeJson(doc, "{\"hello\":\"world\"}");
-      JsonObject obj = doc.as<JsonObject>();
-      REQUIRE(std::string("world") == obj.get<char*>(key));
-    }
-
-    SECTION("set() key") {
-      unsigned char key[] = "hello";
-
-      DynamicJsonDocument doc;
-      JsonObject obj = doc.to<JsonObject>();
-      obj.set(key, "world");
-
-      REQUIRE(std::string("world") == obj["hello"]);
-    }
-
-    SECTION("set() value") {
-      unsigned char value[] = "world";
-
-      DynamicJsonDocument doc;
-      JsonObject obj = doc.to<JsonObject>();
-      obj.set("hello", value);
-
-      REQUIRE(std::string("world") == obj["hello"]);
-    }
-
-    SECTION("set() key&value") {
-      unsigned char key[] = "world";
-
-      DynamicJsonDocument doc;
-      JsonObject obj = doc.to<JsonObject>();
-      obj.set(key, key);
-
-      REQUIRE(std::string("world") == obj["world"]);
-    }
-
     SECTION("containsKey()") {
       unsigned char key[] = "hello";
 
@@ -169,16 +130,6 @@ TEST_CASE("unsigned char[]") {
       REQUIRE(0 == obj.size());
     }
 
-    SECTION("is()") {
-      unsigned char key[] = "hello";
-
-      DynamicJsonDocument doc;
-      deserializeJson(doc, "{\"hello\":42}");
-      JsonObject obj = doc.as<JsonObject>();
-
-      REQUIRE(true == obj.is<int>(key));
-    }
-
     SECTION("createNestedArray()") {
       unsigned char key[] = "hello";
 
@@ -228,17 +179,6 @@ TEST_CASE("unsigned char[]") {
 
       REQUIRE(std::string("world") == arr[0]);
     }
-
-    SECTION("set()") {
-      unsigned char value[] = "world";
-
-      DynamicJsonDocument doc;
-      JsonArray arr = doc.to<JsonArray>();
-      arr.add("hello");
-      arr.set(0, value);
-
-      REQUIRE(std::string("world") == arr[0]);
-    }
   }
 
   SECTION("JsonArraySubscript") {