mirror of
https://github.com/bblanchon/ArduinoJson.git
synced 2025-07-29 10:17:39 +02:00
Fix build on Visual Studio 2010, 2012, MinGW32 and GCC 5
This commit is contained in:
16
appveyor.yml
Normal file
16
appveyor.yml
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
version: 5.1.0.{build}
|
||||||
|
environment:
|
||||||
|
matrix:
|
||||||
|
- CMAKE_GENERATOR: Visual Studio 14 2015
|
||||||
|
- CMAKE_GENERATOR: Visual Studio 12 2013
|
||||||
|
- CMAKE_GENERATOR: Visual Studio 11 2012
|
||||||
|
- CMAKE_GENERATOR: Visual Studio 10 2010
|
||||||
|
- CMAKE_GENERATOR: MinGW Makefiles
|
||||||
|
configuration: Debug
|
||||||
|
before_build:
|
||||||
|
- set PATH=C:\MinGW\bin;%PATH:C:\Program Files\Git\usr\bin;=% # Workaround for CMake not wanting sh.exe on PATH for MinGW
|
||||||
|
- cmake -DCMAKE_BUILD_TYPE=%CONFIGURATION% -G "%CMAKE_GENERATOR%" .
|
||||||
|
build_script:
|
||||||
|
- cmake --build . --config %CONFIGURATION%
|
||||||
|
test_script:
|
||||||
|
- ctest -V .
|
@ -9,11 +9,19 @@
|
|||||||
|
|
||||||
#ifndef ARDUINO
|
#ifndef ARDUINO
|
||||||
|
|
||||||
#include "../TypeTraits/EnableIf.hpp"
|
#include "../Internals/JsonFloat.hpp"
|
||||||
#include "../TypeTraits/IsIntegral.hpp"
|
#include "../Internals/JsonInteger.hpp"
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#if defined(_MSC_VER) && _MSC_VER <= 1800
|
||||||
|
// snprintf has been added in Visual Studio 2015
|
||||||
|
#define ARDUINOJSON_SNPRINTF _snprintf
|
||||||
|
#else
|
||||||
|
#define ARDUINOJSON_SNPRINTF snprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
// This class reproduces Arduino's Print class
|
// This class reproduces Arduino's Print class
|
||||||
class Print {
|
class Print {
|
||||||
@ -22,13 +30,33 @@ class Print {
|
|||||||
|
|
||||||
virtual size_t write(uint8_t) = 0;
|
virtual size_t write(uint8_t) = 0;
|
||||||
|
|
||||||
size_t print(const char[]);
|
size_t print(const char* s) {
|
||||||
size_t print(double, int = 2);
|
size_t n = 0;
|
||||||
|
while (*s) {
|
||||||
|
n += write(*s++);
|
||||||
|
}
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
template <typename TIntegral>
|
size_t print(ArduinoJson::Internals::JsonFloat value, int digits = 2) {
|
||||||
typename ArduinoJson::TypeTraits::EnableIf<
|
char tmp[32];
|
||||||
ArduinoJson::TypeTraits::IsIntegral<TIntegral>::value, size_t>::type
|
|
||||||
print(TIntegral value) {
|
// https://github.com/arduino/Arduino/blob/db8cbf24c99dc930b9ccff1a43d018c81f178535/hardware/arduino/sam/cores/arduino/Print.cpp#L220
|
||||||
|
bool isBigDouble = value > 4294967040.0 || value < -4294967040.0;
|
||||||
|
|
||||||
|
if (isBigDouble) {
|
||||||
|
// Arduino's implementation prints "ovf"
|
||||||
|
// We prefer using the scientific notation, since we have sprintf
|
||||||
|
ARDUINOJSON_SNPRINTF(tmp, sizeof(tmp), "%g", value);
|
||||||
|
} else {
|
||||||
|
// Here we have the exact same output as Arduino's implementation
|
||||||
|
ARDUINOJSON_SNPRINTF(tmp, sizeof(tmp), "%.*f", digits, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
return print(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t print(ArduinoJson::Internals::JsonInteger value) {
|
||||||
// see http://clc-wiki.net/wiki/K%26R2_solutions:Chapter_3:Exercise_4
|
// see http://clc-wiki.net/wiki/K%26R2_solutions:Chapter_3:Exercise_4
|
||||||
char buffer[22];
|
char buffer[22];
|
||||||
|
|
||||||
@ -39,7 +67,7 @@ class Print {
|
|||||||
}
|
}
|
||||||
uint8_t i = 0;
|
uint8_t i = 0;
|
||||||
do {
|
do {
|
||||||
TIntegral digit = value % 10;
|
ArduinoJson::Internals::JsonInteger digit = value % 10;
|
||||||
value /= 10;
|
value /= 10;
|
||||||
buffer[i++] = static_cast<char>(digit >= 0 ? '0' + digit : '0' - digit);
|
buffer[i++] = static_cast<char>(digit >= 0 ? '0' + digit : '0' - digit);
|
||||||
} while (value);
|
} while (value);
|
||||||
@ -51,7 +79,7 @@ class Print {
|
|||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t println();
|
size_t println() { return write('\r') + write('\n'); }
|
||||||
};
|
};
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
@ -77,11 +77,6 @@ inline std::ostream& operator<<(std::ostream& os,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
template <>
|
|
||||||
struct JsonVariant::IsConstructibleFrom<JsonArraySubscript> {
|
|
||||||
static const bool value = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace ArduinoJson
|
} // namespace ArduinoJson
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
@ -92,10 +92,6 @@ inline std::ostream& operator<<(
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct JsonVariant::IsConstructibleFrom<JsonObjectSubscript<T> > {
|
|
||||||
static const bool value = true;
|
|
||||||
};
|
|
||||||
} // namespace ArduinoJson
|
} // namespace ArduinoJson
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
|
@ -18,9 +18,9 @@
|
|||||||
#include "TypeTraits/EnableIf.hpp"
|
#include "TypeTraits/EnableIf.hpp"
|
||||||
#include "TypeTraits/IsFloatingPoint.hpp"
|
#include "TypeTraits/IsFloatingPoint.hpp"
|
||||||
#include "TypeTraits/IsIntegral.hpp"
|
#include "TypeTraits/IsIntegral.hpp"
|
||||||
|
#include "TypeTraits/IsSame.hpp"
|
||||||
#include "TypeTraits/RemoveConst.hpp"
|
#include "TypeTraits/RemoveConst.hpp"
|
||||||
#include "TypeTraits/RemoveReference.hpp"
|
#include "TypeTraits/RemoveReference.hpp"
|
||||||
#include "TypeTraits/IsSame.hpp"
|
|
||||||
|
|
||||||
namespace ArduinoJson {
|
namespace ArduinoJson {
|
||||||
|
|
||||||
@ -191,17 +191,24 @@ inline JsonVariant double_with_n_digits(double value, uint8_t digits) {
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct JsonVariant::IsConstructibleFrom {
|
struct JsonVariant::IsConstructibleFrom {
|
||||||
static const bool value = TypeTraits::IsIntegral<T>::value ||
|
static const bool value =
|
||||||
TypeTraits::IsFloatingPoint<T>::value ||
|
TypeTraits::IsIntegral<T>::value ||
|
||||||
TypeTraits::IsSame<T, bool>::value ||
|
TypeTraits::IsFloatingPoint<T>::value ||
|
||||||
TypeTraits::IsSame<T, char *>::value ||
|
TypeTraits::IsSame<T, bool>::value ||
|
||||||
TypeTraits::IsSame<T, const char *>::value ||
|
TypeTraits::IsSame<T, char *>::value ||
|
||||||
TypeTraits::IsSame<T, JsonArray &>::value ||
|
TypeTraits::IsSame<T, const char *>::value ||
|
||||||
TypeTraits::IsSame<T, const JsonArray &>::value ||
|
TypeTraits::IsSame<T, JsonArray &>::value ||
|
||||||
TypeTraits::IsSame<T, JsonObject &>::value ||
|
TypeTraits::IsSame<T, const JsonArray &>::value ||
|
||||||
TypeTraits::IsSame<T, const JsonObject &>::value ||
|
TypeTraits::IsSame<T, JsonArraySubscript &>::value ||
|
||||||
TypeTraits::IsSame<T, JsonVariant &>::value ||
|
TypeTraits::IsSame<T, const JsonArraySubscript &>::value ||
|
||||||
TypeTraits::IsSame<T, const JsonVariant &>::value;
|
TypeTraits::IsSame<T, JsonObject &>::value ||
|
||||||
|
TypeTraits::IsSame<T, const JsonObject &>::value ||
|
||||||
|
TypeTraits::IsSame<T, JsonObjectSubscript<const char *> &>::value ||
|
||||||
|
TypeTraits::IsSame<T, const JsonObjectSubscript<const char *> &>::value ||
|
||||||
|
TypeTraits::IsSame<T, JsonObjectSubscript<String> &>::value ||
|
||||||
|
TypeTraits::IsSame<T, const JsonObjectSubscript<String> &>::value ||
|
||||||
|
TypeTraits::IsSame<T, JsonVariant &>::value ||
|
||||||
|
TypeTraits::IsSame<T, const JsonVariant &>::value;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "../Configuration.hpp"
|
||||||
#include "IsSame.hpp"
|
#include "IsSame.hpp"
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
@ -25,10 +26,14 @@ struct IsIntegral {
|
|||||||
TypeTraits::IsSame<T, unsigned int>::value ||
|
TypeTraits::IsSame<T, unsigned int>::value ||
|
||||||
TypeTraits::IsSame<T, signed long>::value ||
|
TypeTraits::IsSame<T, signed long>::value ||
|
||||||
TypeTraits::IsSame<T, unsigned long>::value ||
|
TypeTraits::IsSame<T, unsigned long>::value ||
|
||||||
#ifndef ARDUINO
|
#if ARDUINOJSON_USE_LONG_LONG
|
||||||
// on a computer add support for 64 bit
|
TypeTraits::IsSame<T, long long>::value ||
|
||||||
TypeTraits::IsSame<T, int64_t>::value ||
|
TypeTraits::IsSame<T, unsigned long long>::value ||
|
||||||
TypeTraits::IsSame<T, uint64_t>::value ||
|
#endif
|
||||||
|
|
||||||
|
#if ARDUINOJSON_USE_INT64
|
||||||
|
TypeTraits::IsSame<T, __int64>::value ||
|
||||||
|
TypeTraits::IsSame<T, unsigned __int64>::value ||
|
||||||
#endif
|
#endif
|
||||||
TypeTraits::IsSame<T, char>::value;
|
TypeTraits::IsSame<T, char>::value;
|
||||||
};
|
};
|
||||||
|
@ -1,60 +0,0 @@
|
|||||||
// Copyright Benoit Blanchon 2014-2016
|
|
||||||
// MIT License
|
|
||||||
//
|
|
||||||
// Arduino JSON library
|
|
||||||
// https://github.com/bblanchon/ArduinoJson
|
|
||||||
// If you like this project, please add a star!
|
|
||||||
|
|
||||||
#ifndef ARDUINO
|
|
||||||
|
|
||||||
#include "../../include/ArduinoJson/Arduino/Print.hpp"
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <math.h> // for isnan() and isinf()
|
|
||||||
|
|
||||||
// only for GCC 4.9+
|
|
||||||
#if defined(__GNUC__) && \
|
|
||||||
(__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 9))
|
|
||||||
#pragma GCC diagnostic ignored "-Wfloat-conversion"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Visual Studo 2012 didn't have isnan, nor isinf
|
|
||||||
#if defined(_MSC_VER) && _MSC_VER <= 1700
|
|
||||||
#include <float.h>
|
|
||||||
#define isnan(x) _isnan(x)
|
|
||||||
#define isinf(x) (!_finite(x))
|
|
||||||
#endif
|
|
||||||
|
|
||||||
size_t Print::print(const char s[]) {
|
|
||||||
size_t n = 0;
|
|
||||||
while (*s) {
|
|
||||||
n += write(*s++);
|
|
||||||
}
|
|
||||||
return n;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t Print::print(double value, int digits) {
|
|
||||||
// https://github.com/arduino/Arduino/blob/db8cbf24c99dc930b9ccff1a43d018c81f178535/hardware/arduino/sam/cores/arduino/Print.cpp#L218
|
|
||||||
if (isnan(value)) return print("nan");
|
|
||||||
if (isinf(value)) return print("inf");
|
|
||||||
|
|
||||||
char tmp[32];
|
|
||||||
|
|
||||||
// https://github.com/arduino/Arduino/blob/db8cbf24c99dc930b9ccff1a43d018c81f178535/hardware/arduino/sam/cores/arduino/Print.cpp#L220
|
|
||||||
bool isBigDouble = value > 4294967040.0 || value < -4294967040.0;
|
|
||||||
|
|
||||||
if (isBigDouble) {
|
|
||||||
// Arduino's implementation prints "ovf"
|
|
||||||
// We prefer trying to use scientific notation, since we have sprintf
|
|
||||||
sprintf(tmp, "%g", value);
|
|
||||||
} else {
|
|
||||||
// Here we have the exact same output as Arduino's implementation
|
|
||||||
sprintf(tmp, "%.*f", digits, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
return print(tmp);
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t Print::println() { return write('\r') + write('\n'); }
|
|
||||||
|
|
||||||
#endif
|
|
@ -5,8 +5,8 @@
|
|||||||
// https://github.com/bblanchon/ArduinoJson
|
// https://github.com/bblanchon/ArduinoJson
|
||||||
// If you like this project, please add a star!
|
// If you like this project, please add a star!
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
#include <gtest/gtest.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
class JsonArray_Subscript_Tests : public ::testing::Test {
|
class JsonArray_Subscript_Tests : public ::testing::Test {
|
||||||
@ -33,12 +33,14 @@ TEST_(StoreInteger) {
|
|||||||
EXPECT_FALSE(_array[0].is<double>());
|
EXPECT_FALSE(_array[0].is<double>());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_(StoreInt64) {
|
#if ARDUINOJSON_USE_LONG_LONG || ARDUINOJSON_USE_INT64
|
||||||
|
TEST_(StoreLongLong) {
|
||||||
_array[0] = 9223372036854775807;
|
_array[0] = 9223372036854775807;
|
||||||
EXPECT_EQ(9223372036854775807, _array[0].as<int64_t>());
|
EXPECT_EQ(9223372036854775807, _array[0].as<long long>());
|
||||||
EXPECT_TRUE(_array[0].is<int>());
|
EXPECT_TRUE(_array[0].is<int>());
|
||||||
EXPECT_FALSE(_array[0].is<double>());
|
EXPECT_FALSE(_array[0].is<double>());
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
TEST_(StoreDouble) {
|
TEST_(StoreDouble) {
|
||||||
_array[0] = 123.45;
|
_array[0] = 123.45;
|
||||||
|
@ -5,9 +5,9 @@
|
|||||||
// https://github.com/bblanchon/ArduinoJson
|
// https://github.com/bblanchon/ArduinoJson
|
||||||
// If you like this project, please add a star!
|
// If you like this project, please add a star!
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
static const char* null = 0;
|
static const char* null = 0;
|
||||||
@ -137,15 +137,17 @@ TEST(JsonVariant_As_Tests, NumberStringAsLong) {
|
|||||||
ASSERT_EQ(42L, variant.as<long>());
|
ASSERT_EQ(42L, variant.as<long>());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ARDUINOJSON_USE_LONG_LONG || ARDUINOJSON_USE_INT64
|
||||||
TEST(JsonVariant_As_Tests, NumberStringAsInt64Negative) {
|
TEST(JsonVariant_As_Tests, NumberStringAsInt64Negative) {
|
||||||
JsonVariant variant = "-9223372036854775808";
|
JsonVariant variant = "-9223372036854775808";
|
||||||
ASSERT_EQ(-9223372036854775807 - 1, variant.as<int64_t>());
|
ASSERT_EQ(-9223372036854775807 - 1, variant.as<long long>());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(JsonVariant_As_Tests, NumberStringAsInt64Positive) {
|
TEST(JsonVariant_As_Tests, NumberStringAsInt64Positive) {
|
||||||
JsonVariant variant = "9223372036854775807";
|
JsonVariant variant = "9223372036854775807";
|
||||||
ASSERT_EQ(9223372036854775807, variant.as<int64_t>());
|
ASSERT_EQ(9223372036854775807, variant.as<long long>());
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
TEST(JsonVariant_As_Tests, RandomStringAsBool) {
|
TEST(JsonVariant_As_Tests, RandomStringAsBool) {
|
||||||
JsonVariant variant = "hello";
|
JsonVariant variant = "hello";
|
||||||
|
@ -72,6 +72,7 @@ TEST_F(JsonVariant_PrintTo_Tests, OneFalse) {
|
|||||||
outputMustBe("false");
|
outputMustBe("false");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ARDUINOJSON_USE_LONG_LONG || ARDUINOJSON_USE_INT64
|
||||||
TEST_F(JsonVariant_PrintTo_Tests, NegativeInt64) {
|
TEST_F(JsonVariant_PrintTo_Tests, NegativeInt64) {
|
||||||
variant = -9223372036854775807 - 1;
|
variant = -9223372036854775807 - 1;
|
||||||
outputMustBe("-9223372036854775808");
|
outputMustBe("-9223372036854775808");
|
||||||
@ -81,3 +82,4 @@ TEST_F(JsonVariant_PrintTo_Tests, PositiveInt64) {
|
|||||||
variant = 9223372036854775807;
|
variant = 9223372036854775807;
|
||||||
outputMustBe("9223372036854775807");
|
outputMustBe("9223372036854775807");
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
@ -5,9 +5,9 @@
|
|||||||
// https://github.com/bblanchon/ArduinoJson
|
// https://github.com/bblanchon/ArduinoJson
|
||||||
// If you like this project, please add a star!
|
// If you like this project, please add a star!
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <limits>
|
#include <limits>
|
||||||
#include <gtest/gtest.h>
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
class JsonVariant_Storage_Tests : public ::testing::Test {
|
class JsonVariant_Storage_Tests : public ::testing::Test {
|
||||||
@ -37,9 +37,11 @@ class JsonVariant_Storage_Tests : public ::testing::Test {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if ARDUINOJSON_USE_LONG_LONG || ARDUINOJSON_USE_INT64
|
||||||
TEST_F(JsonVariant_Storage_Tests, SizeOfJsonInteger) {
|
TEST_F(JsonVariant_Storage_Tests, SizeOfJsonInteger) {
|
||||||
ASSERT_EQ(8, sizeof(Internals::JsonInteger));
|
ASSERT_EQ(8, sizeof(Internals::JsonInteger));
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
TEST_F(JsonVariant_Storage_Tests, Null) { testValue<const char *>(NULL); }
|
TEST_F(JsonVariant_Storage_Tests, Null) { testValue<const char *>(NULL); }
|
||||||
TEST_F(JsonVariant_Storage_Tests, String) { testValue<const char *>("hello"); }
|
TEST_F(JsonVariant_Storage_Tests, String) { testValue<const char *>("hello"); }
|
||||||
@ -57,15 +59,21 @@ TEST_F(JsonVariant_Storage_Tests, UChar) { testNumericType<unsigned char>(); }
|
|||||||
TEST_F(JsonVariant_Storage_Tests, UInt) { testNumericType<unsigned int>(); }
|
TEST_F(JsonVariant_Storage_Tests, UInt) { testNumericType<unsigned int>(); }
|
||||||
TEST_F(JsonVariant_Storage_Tests, ULong) { testNumericType<unsigned long>(); }
|
TEST_F(JsonVariant_Storage_Tests, ULong) { testNumericType<unsigned long>(); }
|
||||||
TEST_F(JsonVariant_Storage_Tests, UShort) { testNumericType<unsigned short>(); }
|
TEST_F(JsonVariant_Storage_Tests, UShort) { testNumericType<unsigned short>(); }
|
||||||
|
#if ARDUINOJSON_USE_LONG_LONG || ARDUINOJSON_USE_INT64
|
||||||
|
TEST_F(JsonVariant_Storage_Tests, LongLong) { testNumericType<unsigned long long>(); }
|
||||||
|
TEST_F(JsonVariant_Storage_Tests, ULongLong) { testNumericType<unsigned long long>(); }
|
||||||
|
#endif
|
||||||
|
|
||||||
TEST_F(JsonVariant_Storage_Tests, Int8) { testNumericType<int8_t>(); }
|
TEST_F(JsonVariant_Storage_Tests, Int8) { testNumericType<int8_t>(); }
|
||||||
TEST_F(JsonVariant_Storage_Tests, Int16) { testNumericType<int16_t>(); }
|
|
||||||
TEST_F(JsonVariant_Storage_Tests, Int32) { testNumericType<int32_t>(); }
|
|
||||||
TEST_F(JsonVariant_Storage_Tests, Int64) { testNumericType<int64_t>(); }
|
|
||||||
TEST_F(JsonVariant_Storage_Tests, Uint8) { testNumericType<uint8_t>(); }
|
TEST_F(JsonVariant_Storage_Tests, Uint8) { testNumericType<uint8_t>(); }
|
||||||
|
TEST_F(JsonVariant_Storage_Tests, Int16) { testNumericType<int16_t>(); }
|
||||||
TEST_F(JsonVariant_Storage_Tests, Uint16) { testNumericType<uint16_t>(); }
|
TEST_F(JsonVariant_Storage_Tests, Uint16) { testNumericType<uint16_t>(); }
|
||||||
|
TEST_F(JsonVariant_Storage_Tests, Int32) { testNumericType<int32_t>(); }
|
||||||
TEST_F(JsonVariant_Storage_Tests, Uint32) { testNumericType<uint32_t>(); }
|
TEST_F(JsonVariant_Storage_Tests, Uint32) { testNumericType<uint32_t>(); }
|
||||||
|
#if ARDUINOJSON_USE_LONG_LONG || ARDUINOJSON_USE_INT64
|
||||||
|
TEST_F(JsonVariant_Storage_Tests, Int64) { testNumericType<int64_t>(); }
|
||||||
TEST_F(JsonVariant_Storage_Tests, Uint64) { testNumericType<uint64_t>(); }
|
TEST_F(JsonVariant_Storage_Tests, Uint64) { testNumericType<uint64_t>(); }
|
||||||
|
#endif
|
||||||
|
|
||||||
TEST_F(JsonVariant_Storage_Tests, CanStoreObject) {
|
TEST_F(JsonVariant_Storage_Tests, CanStoreObject) {
|
||||||
DynamicJsonBuffer jsonBuffer;
|
DynamicJsonBuffer jsonBuffer;
|
||||||
|
Reference in New Issue
Block a user