8#ifndef BOTAN_SECURE_MEMORY_BUFFERS_H_
9#define BOTAN_SECURE_MEMORY_BUFFERS_H_
11#include <botan/types.h>
12#include <botan/mem_ops.h>
31#if !defined(_ITERATOR_DEBUG_LEVEL) || _ITERATOR_DEBUG_LEVEL == 0
32 static_assert(std::is_integral<T>::value,
"secure_allocator supports only integer types");
57template<
typename T,
typename U>
inline bool
61template<
typename T,
typename U>
inline bool
65template<
typename T>
using secure_vector = std::vector<T, secure_allocator<T>>;
66template<
typename T>
using secure_deque = std::deque<T, secure_allocator<T>>;
74 return std::vector<T>(in.begin(), in.end());
77template<
typename T,
typename Alloc,
typename Alloc2>
80 const std::vector<T, Alloc2>& in)
82 out.insert(out.end(), in.begin(), in.end());
86template<
typename T,
typename Alloc>
87std::vector<T, Alloc>&
operator+=(std::vector<T, Alloc>& out,
T in)
93template<
typename T,
typename Alloc,
typename L>
94std::vector<T, Alloc>&
operator+=(std::vector<T, Alloc>& out,
95 const std::pair<const T*, L>& in)
97 out.insert(out.end(), in.first, in.first + in.second);
101template<
typename T,
typename Alloc,
typename L>
103 const std::pair<T*, L>& in)
105 out.insert(out.end(), in.first, in.first + in.second);
113template<
typename T,
typename Alloc>
123template<
typename T,
typename Alloc>
124void zap(std::vector<T, Alloc>& vec)
T * allocate(std::size_t n)
void deallocate(T *p, std::size_t n)
secure_allocator() noexcept=default
void zeroise(std::vector< T, Alloc > &vec)
std::deque< T, secure_allocator< T > > secure_deque
BOTAN_MALLOC_FN void * allocate_memory(size_t elems, size_t elem_size)
void zap(std::vector< T, Alloc > &vec)
void deallocate_memory(void *p, size_t elems, size_t elem_size)
bool operator!=(const AlgorithmIdentifier &a1, const AlgorithmIdentifier &a2)
std::vector< T > unlock(const secure_vector< T > &in)
bool operator==(const AlgorithmIdentifier &a1, const AlgorithmIdentifier &a2)
std::vector< T, Alloc > & operator+=(std::vector< T, Alloc > &out, const std::vector< T, Alloc2 > &in)
std::vector< T, secure_allocator< T > > secure_vector
constexpr void clear_mem(T *ptr, size_t n)
secure_vector< T > SecureVector