Mercurial > minori
view dep/fmt/test/mock-allocator.h @ 350:daa03aa2262d
sys/glib: general cleanup, use C++ principles, add more suffixes
author | Paper <paper@paper.us.eu.org> |
---|---|
date | Sun, 14 Jul 2024 19:12:40 -0400 |
parents | 1faa72660932 |
children |
line wrap: on
line source
// Formatting library for C++ - mock allocator // // Copyright (c) 2012 - present, Victor Zverovich // All rights reserved. // // For the license information refer to format.h. #ifndef FMT_MOCK_ALLOCATOR_H_ #define FMT_MOCK_ALLOCATOR_H_ #include <assert.h> // assert #include <stddef.h> // size_t #include <memory> // std::allocator_traits #include "gmock/gmock.h" template <typename T> class mock_allocator { public: mock_allocator() {} mock_allocator(const mock_allocator&) {} using value_type = T; MOCK_METHOD(T*, allocate, (size_t)); MOCK_METHOD(void, deallocate, (T*, size_t)); }; template <typename Allocator> class allocator_ref { private: Allocator* alloc_; void move(allocator_ref& other) { alloc_ = other.alloc_; other.alloc_ = nullptr; } public: using value_type = typename Allocator::value_type; explicit allocator_ref(Allocator* alloc = nullptr) : alloc_(alloc) {} allocator_ref(const allocator_ref& other) : alloc_(other.alloc_) {} allocator_ref(allocator_ref&& other) { move(other); } allocator_ref& operator=(allocator_ref&& other) { assert(this != &other); move(other); return *this; } allocator_ref& operator=(const allocator_ref& other) { alloc_ = other.alloc_; return *this; } public: Allocator* get() const { return alloc_; } value_type* allocate(size_t n) { return std::allocator_traits<Allocator>::allocate(*alloc_, n); } void deallocate(value_type* p, size_t n) { alloc_->deallocate(p, n); } }; #endif // FMT_MOCK_ALLOCATOR_H_