mirror of
https://github.com/minetest/minetest.git
synced 2025-01-01 19:07:31 +01:00
447 lines
14 KiB
C++
447 lines
14 KiB
C++
/// Json-cpp amalgamated forward header (http://jsoncpp.sourceforge.net/).
|
|
/// It is intended to be used with #include "json/json-forwards.h"
|
|
/// This header provides forward declaration for all JsonCpp types.
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// Beginning of content of file: LICENSE
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
/*
|
|
The JsonCpp library's source code, including accompanying documentation,
|
|
tests and demonstration applications, are licensed under the following
|
|
conditions...
|
|
|
|
Baptiste Lepilleur and The JsonCpp Authors explicitly disclaim copyright in all
|
|
jurisdictions which recognize such a disclaimer. In such jurisdictions,
|
|
this software is released into the Public Domain.
|
|
|
|
In jurisdictions which do not recognize Public Domain property (e.g. Germany as of
|
|
2010), this software is Copyright (c) 2007-2010 by Baptiste Lepilleur and
|
|
The JsonCpp Authors, and is released under the terms of the MIT License (see below).
|
|
|
|
In jurisdictions which recognize Public Domain property, the user of this
|
|
software may choose to accept it either as 1) Public Domain, 2) under the
|
|
conditions of the MIT License (see below), or 3) under the terms of dual
|
|
Public Domain/MIT License conditions described here, as they choose.
|
|
|
|
The MIT License is about as close to Public Domain as a license can get, and is
|
|
described in clear, concise terms at:
|
|
|
|
http://en.wikipedia.org/wiki/MIT_License
|
|
|
|
The full text of the MIT License follows:
|
|
|
|
========================================================================
|
|
Copyright (c) 2007-2010 Baptiste Lepilleur and The JsonCpp Authors
|
|
|
|
Permission is hereby granted, free of charge, to any person
|
|
obtaining a copy of this software and associated documentation
|
|
files (the "Software"), to deal in the Software without
|
|
restriction, including without limitation the rights to use, copy,
|
|
modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
of the Software, and to permit persons to whom the Software is
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
The above copyright notice and this permission notice shall be
|
|
included in all copies or substantial portions of the Software.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
SOFTWARE.
|
|
========================================================================
|
|
(END LICENSE TEXT)
|
|
|
|
The MIT license is compatible with both the GPL and commercial
|
|
software, affording one all of the rights of Public Domain with the
|
|
minor nuisance of being required to keep the above copyright notice
|
|
and license text in the source code. Note also that by accepting the
|
|
Public Domain "license" you can re-license your copy using whatever
|
|
license you like.
|
|
|
|
*/
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// End of content of file: LICENSE
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef JSON_FORWARD_AMALGAMATED_H_INCLUDED
|
|
# define JSON_FORWARD_AMALGAMATED_H_INCLUDED
|
|
/// If defined, indicates that the source file is amalgamated
|
|
/// to prevent private header inclusion.
|
|
#define JSON_IS_AMALGAMATION
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// Beginning of content of file: include/json/version.h
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef JSON_VERSION_H_INCLUDED
|
|
#define JSON_VERSION_H_INCLUDED
|
|
|
|
// Note: version must be updated in three places when doing a release. This
|
|
// annoying process ensures that amalgamate, CMake, and meson all report the
|
|
// correct version.
|
|
// 1. /meson.build
|
|
// 2. /include/json/version.h
|
|
// 3. /CMakeLists.txt
|
|
// IMPORTANT: also update the SOVERSION!!
|
|
|
|
#define JSONCPP_VERSION_STRING "1.9.5"
|
|
#define JSONCPP_VERSION_MAJOR 1
|
|
#define JSONCPP_VERSION_MINOR 9
|
|
#define JSONCPP_VERSION_PATCH 5
|
|
#define JSONCPP_VERSION_QUALIFIER
|
|
#define JSONCPP_VERSION_HEXA \
|
|
((JSONCPP_VERSION_MAJOR << 24) | (JSONCPP_VERSION_MINOR << 16) | \
|
|
(JSONCPP_VERSION_PATCH << 8))
|
|
|
|
#ifdef JSONCPP_USING_SECURE_MEMORY
|
|
#undef JSONCPP_USING_SECURE_MEMORY
|
|
#endif
|
|
#define JSONCPP_USING_SECURE_MEMORY 0
|
|
// If non-zero, the library zeroes any memory that it has allocated before
|
|
// it frees its memory.
|
|
|
|
#endif // JSON_VERSION_H_INCLUDED
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// End of content of file: include/json/version.h
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// Beginning of content of file: include/json/allocator.h
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
// Copyright 2007-2010 Baptiste Lepilleur and The JsonCpp Authors
|
|
// Distributed under MIT license, or public domain if desired and
|
|
// recognized in your jurisdiction.
|
|
// See file LICENSE for detail or copy at http://jsoncpp.sourceforge.net/LICENSE
|
|
|
|
#ifndef JSON_ALLOCATOR_H_INCLUDED
|
|
#define JSON_ALLOCATOR_H_INCLUDED
|
|
|
|
#include <cstring>
|
|
#include <memory>
|
|
|
|
#pragma pack(push, 8)
|
|
|
|
namespace Json {
|
|
template <typename T> class SecureAllocator {
|
|
public:
|
|
// Type definitions
|
|
using value_type = T;
|
|
using pointer = T*;
|
|
using const_pointer = const T*;
|
|
using reference = T&;
|
|
using const_reference = const T&;
|
|
using size_type = std::size_t;
|
|
using difference_type = std::ptrdiff_t;
|
|
|
|
/**
|
|
* Allocate memory for N items using the standard allocator.
|
|
*/
|
|
pointer allocate(size_type n) {
|
|
// allocate using "global operator new"
|
|
return static_cast<pointer>(::operator new(n * sizeof(T)));
|
|
}
|
|
|
|
/**
|
|
* Release memory which was allocated for N items at pointer P.
|
|
*
|
|
* The memory block is filled with zeroes before being released.
|
|
*/
|
|
void deallocate(pointer p, size_type n) {
|
|
// memset_s is used because memset may be optimized away by the compiler
|
|
memset_s(p, n * sizeof(T), 0, n * sizeof(T));
|
|
// free using "global operator delete"
|
|
::operator delete(p);
|
|
}
|
|
|
|
/**
|
|
* Construct an item in-place at pointer P.
|
|
*/
|
|
template <typename... Args> void construct(pointer p, Args&&... args) {
|
|
// construct using "placement new" and "perfect forwarding"
|
|
::new (static_cast<void*>(p)) T(std::forward<Args>(args)...);
|
|
}
|
|
|
|
size_type max_size() const { return size_t(-1) / sizeof(T); }
|
|
|
|
pointer address(reference x) const { return std::addressof(x); }
|
|
|
|
const_pointer address(const_reference x) const { return std::addressof(x); }
|
|
|
|
/**
|
|
* Destroy an item in-place at pointer P.
|
|
*/
|
|
void destroy(pointer p) {
|
|
// destroy using "explicit destructor"
|
|
p->~T();
|
|
}
|
|
|
|
// Boilerplate
|
|
SecureAllocator() {}
|
|
template <typename U> SecureAllocator(const SecureAllocator<U>&) {}
|
|
template <typename U> struct rebind { using other = SecureAllocator<U>; };
|
|
};
|
|
|
|
template <typename T, typename U>
|
|
bool operator==(const SecureAllocator<T>&, const SecureAllocator<U>&) {
|
|
return true;
|
|
}
|
|
|
|
template <typename T, typename U>
|
|
bool operator!=(const SecureAllocator<T>&, const SecureAllocator<U>&) {
|
|
return false;
|
|
}
|
|
|
|
} // namespace Json
|
|
|
|
#pragma pack(pop)
|
|
|
|
#endif // JSON_ALLOCATOR_H_INCLUDED
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// End of content of file: include/json/allocator.h
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// Beginning of content of file: include/json/config.h
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
// Copyright 2007-2010 Baptiste Lepilleur and The JsonCpp Authors
|
|
// Distributed under MIT license, or public domain if desired and
|
|
// recognized in your jurisdiction.
|
|
// See file LICENSE for detail or copy at http://jsoncpp.sourceforge.net/LICENSE
|
|
|
|
#ifndef JSON_CONFIG_H_INCLUDED
|
|
#define JSON_CONFIG_H_INCLUDED
|
|
#include <cstddef>
|
|
#include <cstdint>
|
|
#include <istream>
|
|
#include <memory>
|
|
#include <ostream>
|
|
#include <sstream>
|
|
#include <string>
|
|
#include <type_traits>
|
|
|
|
// If non-zero, the library uses exceptions to report bad input instead of C
|
|
// assertion macros. The default is to use exceptions.
|
|
#ifndef JSON_USE_EXCEPTION
|
|
#define JSON_USE_EXCEPTION 1
|
|
#endif
|
|
|
|
// Temporary, tracked for removal with issue #982.
|
|
#ifndef JSON_USE_NULLREF
|
|
#define JSON_USE_NULLREF 1
|
|
#endif
|
|
|
|
/// If defined, indicates that the source file is amalgamated
|
|
/// to prevent private header inclusion.
|
|
/// Remarks: it is automatically defined in the generated amalgamated header.
|
|
// #define JSON_IS_AMALGAMATION
|
|
|
|
// Export macros for DLL visibility
|
|
#if defined(JSON_DLL_BUILD)
|
|
#if defined(_MSC_VER) || defined(__MINGW32__)
|
|
#define JSON_API __declspec(dllexport)
|
|
#define JSONCPP_DISABLE_DLL_INTERFACE_WARNING
|
|
#elif defined(__GNUC__) || defined(__clang__)
|
|
#define JSON_API __attribute__((visibility("default")))
|
|
#endif // if defined(_MSC_VER)
|
|
|
|
#elif defined(JSON_DLL)
|
|
#if defined(_MSC_VER) || defined(__MINGW32__)
|
|
#define JSON_API __declspec(dllimport)
|
|
#define JSONCPP_DISABLE_DLL_INTERFACE_WARNING
|
|
#endif // if defined(_MSC_VER)
|
|
#endif // ifdef JSON_DLL_BUILD
|
|
|
|
#if !defined(JSON_API)
|
|
#define JSON_API
|
|
#endif
|
|
|
|
#if defined(_MSC_VER) && _MSC_VER < 1800
|
|
#error \
|
|
"ERROR: Visual Studio 12 (2013) with _MSC_VER=1800 is the oldest supported compiler with sufficient C++11 capabilities"
|
|
#endif
|
|
|
|
#if defined(_MSC_VER) && _MSC_VER < 1900
|
|
// As recommended at
|
|
// https://stackoverflow.com/questions/2915672/snprintf-and-visual-studio-2010
|
|
extern JSON_API int msvc_pre1900_c99_snprintf(char* outBuf, size_t size,
|
|
const char* format, ...);
|
|
#define jsoncpp_snprintf msvc_pre1900_c99_snprintf
|
|
#else
|
|
#define jsoncpp_snprintf std::snprintf
|
|
#endif
|
|
|
|
// If JSON_NO_INT64 is defined, then Json only support C++ "int" type for
|
|
// integer
|
|
// Storages, and 64 bits integer support is disabled.
|
|
// #define JSON_NO_INT64 1
|
|
|
|
// JSONCPP_OVERRIDE is maintained for backwards compatibility of external tools.
|
|
// C++11 should be used directly in JSONCPP.
|
|
#define JSONCPP_OVERRIDE override
|
|
|
|
#ifdef __clang__
|
|
#if __has_extension(attribute_deprecated_with_message)
|
|
#define JSONCPP_DEPRECATED(message) __attribute__((deprecated(message)))
|
|
#endif
|
|
#elif defined(__GNUC__) // not clang (gcc comes later since clang emulates gcc)
|
|
#if (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5))
|
|
#define JSONCPP_DEPRECATED(message) __attribute__((deprecated(message)))
|
|
#elif (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 1))
|
|
#define JSONCPP_DEPRECATED(message) __attribute__((__deprecated__))
|
|
#endif // GNUC version
|
|
#elif defined(_MSC_VER) // MSVC (after clang because clang on Windows emulates
|
|
// MSVC)
|
|
#define JSONCPP_DEPRECATED(message) __declspec(deprecated(message))
|
|
#endif // __clang__ || __GNUC__ || _MSC_VER
|
|
|
|
#if !defined(JSONCPP_DEPRECATED)
|
|
#define JSONCPP_DEPRECATED(message)
|
|
#endif // if !defined(JSONCPP_DEPRECATED)
|
|
|
|
#if defined(__clang__) || (defined(__GNUC__) && (__GNUC__ >= 6))
|
|
#define JSON_USE_INT64_DOUBLE_CONVERSION 1
|
|
#endif
|
|
|
|
#if !defined(JSON_IS_AMALGAMATION)
|
|
|
|
#include "allocator.h"
|
|
#include "version.h"
|
|
|
|
#endif // if !defined(JSON_IS_AMALGAMATION)
|
|
|
|
namespace Json {
|
|
using Int = int;
|
|
using UInt = unsigned int;
|
|
#if defined(JSON_NO_INT64)
|
|
using LargestInt = int;
|
|
using LargestUInt = unsigned int;
|
|
#undef JSON_HAS_INT64
|
|
#else // if defined(JSON_NO_INT64)
|
|
// For Microsoft Visual use specific types as long long is not supported
|
|
#if defined(_MSC_VER) // Microsoft Visual Studio
|
|
using Int64 = __int64;
|
|
using UInt64 = unsigned __int64;
|
|
#else // if defined(_MSC_VER) // Other platforms, use long long
|
|
using Int64 = int64_t;
|
|
using UInt64 = uint64_t;
|
|
#endif // if defined(_MSC_VER)
|
|
using LargestInt = Int64;
|
|
using LargestUInt = UInt64;
|
|
#define JSON_HAS_INT64
|
|
#endif // if defined(JSON_NO_INT64)
|
|
|
|
template <typename T>
|
|
using Allocator =
|
|
typename std::conditional<JSONCPP_USING_SECURE_MEMORY, SecureAllocator<T>,
|
|
std::allocator<T>>::type;
|
|
using String = std::basic_string<char, std::char_traits<char>, Allocator<char>>;
|
|
using IStringStream =
|
|
std::basic_istringstream<String::value_type, String::traits_type,
|
|
String::allocator_type>;
|
|
using OStringStream =
|
|
std::basic_ostringstream<String::value_type, String::traits_type,
|
|
String::allocator_type>;
|
|
using IStream = std::istream;
|
|
using OStream = std::ostream;
|
|
} // namespace Json
|
|
|
|
// Legacy names (formerly macros).
|
|
using JSONCPP_STRING = Json::String;
|
|
using JSONCPP_ISTRINGSTREAM = Json::IStringStream;
|
|
using JSONCPP_OSTRINGSTREAM = Json::OStringStream;
|
|
using JSONCPP_ISTREAM = Json::IStream;
|
|
using JSONCPP_OSTREAM = Json::OStream;
|
|
|
|
#endif // JSON_CONFIG_H_INCLUDED
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// End of content of file: include/json/config.h
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// Beginning of content of file: include/json/forwards.h
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
// Copyright 2007-2010 Baptiste Lepilleur and The JsonCpp Authors
|
|
// Distributed under MIT license, or public domain if desired and
|
|
// recognized in your jurisdiction.
|
|
// See file LICENSE for detail or copy at http://jsoncpp.sourceforge.net/LICENSE
|
|
|
|
#ifndef JSON_FORWARDS_H_INCLUDED
|
|
#define JSON_FORWARDS_H_INCLUDED
|
|
|
|
#if !defined(JSON_IS_AMALGAMATION)
|
|
#include "config.h"
|
|
#endif // if !defined(JSON_IS_AMALGAMATION)
|
|
|
|
namespace Json {
|
|
|
|
// writer.h
|
|
class StreamWriter;
|
|
class StreamWriterBuilder;
|
|
class Writer;
|
|
class FastWriter;
|
|
class StyledWriter;
|
|
class StyledStreamWriter;
|
|
|
|
// reader.h
|
|
class Reader;
|
|
class CharReader;
|
|
class CharReaderBuilder;
|
|
|
|
// json_features.h
|
|
class Features;
|
|
|
|
// value.h
|
|
using ArrayIndex = unsigned int;
|
|
class StaticString;
|
|
class Path;
|
|
class PathArgument;
|
|
class Value;
|
|
class ValueIteratorBase;
|
|
class ValueIterator;
|
|
class ValueConstIterator;
|
|
|
|
} // namespace Json
|
|
|
|
#endif // JSON_FORWARDS_H_INCLUDED
|
|
|
|
// //////////////////////////////////////////////////////////////////////
|
|
// End of content of file: include/json/forwards.h
|
|
// //////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
|
|
#endif //ifndef JSON_FORWARD_AMALGAMATED_H_INCLUDED
|