tqcq
ed0dfc9c6f
Some checks failed
linux-mips-gcc / linux-gcc-mipsel (Debug) (push) Waiting to run
linux-mips-gcc / linux-gcc-mipsel (Release) (push) Waiting to run
linux-mips64-gcc / linux-gcc-mips64el (Debug) (push) Waiting to run
linux-mips64-gcc / linux-gcc-mips64el (Release) (push) Waiting to run
linux-riscv64-gcc / linux-gcc-riscv64 (Debug) (push) Waiting to run
linux-riscv64-gcc / linux-gcc-riscv64 (Release) (push) Waiting to run
linux-x64-gcc / linux-gcc (Debug) (push) Waiting to run
linux-x64-gcc / linux-gcc (Release) (push) Waiting to run
linux-x86-gcc / linux-gcc (Debug) (push) Waiting to run
linux-x86-gcc / linux-gcc (Release) (push) Waiting to run
linux-aarch64-cpu-gcc / linux-gcc-aarch64 (Debug) (push) Successful in 1m32s
linux-aarch64-cpu-gcc / linux-gcc-aarch64 (Release) (push) Failing after 9s
linux-arm-gcc / linux-gcc-arm (Debug) (push) Successful in 1m45s
linux-arm-gcc / linux-gcc-arm (Release) (push) Successful in 1m38s
linux-arm-gcc / linux-gcc-armhf (Debug) (push) Successful in 2m1s
linux-arm-gcc / linux-gcc-armhf (Release) (push) Has been cancelled
89 lines
2.4 KiB
C++
89 lines
2.4 KiB
C++
// 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
|