mirror of
				https://github.com/eledio-devices/thirdparty-ArduinoJson.git
				synced 2025-10-31 08:42:39 +01:00 
			
		
		
		
	Fixed JsonVariant::as<unsigned>() (fixes #1601)
				
					
				
			This commit is contained in:
		| @@ -12,6 +12,7 @@ HEAD | ||||
| * Added support for `std::string_view` (issue #1578, PR #1554 by @0xFEEDC0DE64) | ||||
| * Fixed warning `definition of implicit copy constructor for 'MsgPackDeserializer' is deprecated because it has a user-declared copy assignment operator` | ||||
| * Added `JsonArray::clear()` (issue #1597) | ||||
| * Fixed `JsonVariant::as<unsigned>()` (issue #1601) | ||||
|  | ||||
| v6.18.0 (2021-05-05) | ||||
| ------- | ||||
|   | ||||
| @@ -61,6 +61,16 @@ TEST_CASE("JsonVariant::as()") { | ||||
|     REQUIRE(variant.as<std::string>() == "true"); | ||||
|   } | ||||
|  | ||||
|   SECTION("set(42)") { | ||||
|     variant.set(42); | ||||
|  | ||||
|     REQUIRE(variant.as<bool>() == true); | ||||
|     REQUIRE(variant.as<double>() == 42.0); | ||||
|     REQUIRE(variant.as<int>() == 42); | ||||
|     REQUIRE(variant.as<unsigned int>() == 42U);  // issue #1601 | ||||
|     REQUIRE(variant.as<std::string>() == "42"); | ||||
|   } | ||||
|  | ||||
|   SECTION("set(42L)") { | ||||
|     variant.set(42L); | ||||
|  | ||||
|   | ||||
| @@ -3,6 +3,7 @@ | ||||
| # MIT License | ||||
|  | ||||
| add_executable(NumbersTests  | ||||
| 	convertNumber.cpp | ||||
| 	parseFloat.cpp | ||||
| 	parseDouble.cpp | ||||
| 	parseInteger.cpp | ||||
|   | ||||
							
								
								
									
										78
									
								
								extras/tests/Numbers/convertNumber.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								extras/tests/Numbers/convertNumber.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | ||||
| // ArduinoJson - https://arduinojson.org | ||||
| // Copyright Benoit Blanchon 2014-2021 | ||||
| // MIT License | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <ArduinoJson.hpp> | ||||
| #include <catch.hpp> | ||||
|  | ||||
| using namespace ARDUINOJSON_NAMESPACE; | ||||
|  | ||||
| TEST_CASE("canConvertNumber<TOut, TIn>()") { | ||||
|   SECTION("int8_t -> int8_t") { | ||||
|     CHECK((canConvertNumber<int8_t, int8_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<int8_t, int8_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<int8_t, int8_t>(-128)) == true); | ||||
|   } | ||||
|  | ||||
|   SECTION("int8_t -> int16_t") { | ||||
|     CHECK((canConvertNumber<int16_t, int8_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<int16_t, int8_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<int16_t, int8_t>(-128)) == true); | ||||
|   } | ||||
|  | ||||
|   SECTION("int8_t -> uint8_t") { | ||||
|     CHECK((canConvertNumber<uint8_t, int8_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<uint8_t, int8_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<uint8_t, int8_t>(-128)) == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("int8_t -> uint16_t") { | ||||
|     CHECK((canConvertNumber<uint16_t, int8_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<uint16_t, int8_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<uint16_t, int8_t>(-128)) == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("int16_t -> int8_t") { | ||||
|     CHECK((canConvertNumber<int8_t, int16_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<int8_t, int16_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<int8_t, int16_t>(128)) == false); | ||||
|     CHECK((canConvertNumber<int8_t, int16_t>(-128)) == true); | ||||
|     CHECK((canConvertNumber<int8_t, int16_t>(-129)) == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("int16_t -> uint8_t") { | ||||
|     CHECK((canConvertNumber<uint8_t, int16_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<uint8_t, int16_t>(255)) == true); | ||||
|     CHECK((canConvertNumber<uint8_t, int16_t>(256)) == false); | ||||
|     CHECK((canConvertNumber<uint8_t, int16_t>(-1)) == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("uint8_t -> int8_t") { | ||||
|     CHECK((canConvertNumber<int8_t, uint8_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<int8_t, uint8_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<int8_t, uint8_t>(128)) == false); | ||||
|     CHECK((canConvertNumber<int8_t, uint8_t>(255)) == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("uint8_t -> int16_t") { | ||||
|     CHECK((canConvertNumber<int16_t, uint8_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<int16_t, uint8_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<int16_t, uint8_t>(128)) == true); | ||||
|     CHECK((canConvertNumber<int16_t, uint8_t>(255)) == true); | ||||
|   } | ||||
|  | ||||
|   SECTION("uint8_t -> uint8_t") { | ||||
|     CHECK((canConvertNumber<uint8_t, uint8_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<uint8_t, uint8_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<uint8_t, uint8_t>(128)) == true); | ||||
|     CHECK((canConvertNumber<uint8_t, uint8_t>(255)) == true); | ||||
|   } | ||||
|  | ||||
|   SECTION("uint8_t -> uint16_t") { | ||||
|     CHECK((canConvertNumber<uint16_t, uint8_t>(0)) == true); | ||||
|     CHECK((canConvertNumber<uint16_t, uint8_t>(127)) == true); | ||||
|     CHECK((canConvertNumber<uint16_t, uint8_t>(128)) == true); | ||||
|     CHECK((canConvertNumber<uint16_t, uint8_t>(255)) == true); | ||||
|   } | ||||
| } | ||||
| @@ -71,9 +71,23 @@ canConvertNumber(TIn) { | ||||
| } | ||||
|  | ||||
| // int32 -> uint32 | ||||
| // int32 -> uint64 | ||||
| template <typename TOut, typename TIn> | ||||
| typename enable_if<is_integral<TIn>::value && is_signed<TIn>::value && | ||||
|                        is_integral<TOut>::value && is_unsigned<TOut>::value, | ||||
|                        is_integral<TOut>::value && is_unsigned<TOut>::value && | ||||
|                        sizeof(TOut) >= sizeof(TIn), | ||||
|                    bool>::type | ||||
| canConvertNumber(TIn value) { | ||||
|   if (value < 0) | ||||
|     return false; | ||||
|   return TOut(value) <= numeric_limits<TOut>::highest(); | ||||
| } | ||||
|  | ||||
| // int32 -> uint16 | ||||
| template <typename TOut, typename TIn> | ||||
| typename enable_if<is_integral<TIn>::value && is_signed<TIn>::value && | ||||
|                        is_integral<TOut>::value && is_unsigned<TOut>::value && | ||||
|                        sizeof(TOut) < sizeof(TIn), | ||||
|                    bool>::type | ||||
| canConvertNumber(TIn value) { | ||||
|   if (value < 0) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user