Danny Robson
7af076e2de
this allows the users to more easily walk the byte ranges (or perform simply pointer arithmetic), without as much danger of using the values in an expression inadvertantly.
49 lines
1.6 KiB
C++
49 lines
1.6 KiB
C++
/*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
* Copyright 2015 Danny Robson <danny@nerdcruft.net>
|
|
*/
|
|
|
|
#ifndef CRUFT_UTIL_ALLOC_RAW_AFFIX_HPP
|
|
#define CRUFT_UTIL_ALLOC_RAW_AFFIX_HPP
|
|
|
|
#include <cstddef>
|
|
|
|
namespace util::alloc::raw {
|
|
/// a raw memory allocator which initialises an instance of PrefixT
|
|
/// immediately before each allocation and, if specified, an instance
|
|
/// of SuffixT after the allocation.
|
|
///
|
|
/// uses an instance of ParentT to actually perform the bulk allocations.
|
|
///
|
|
/// useful for sentinels, reference counts, etc.
|
|
template <class ParentT, class PrefixT, class SuffixT>
|
|
class affix {
|
|
void* allocate (size_t bytes);
|
|
void* allocate (size_t bytes, size_t align);
|
|
|
|
void deallocate (void *ptr, size_t bytes);
|
|
void deallocate (void *ptr, size_t bytes, size_t align);
|
|
|
|
std::byte* begin (void);
|
|
const std::byte* begin (void) const;
|
|
|
|
std::byte* end (void);
|
|
const std::byte* end (void) const;
|
|
|
|
size_t offset (const void*) const;
|
|
};
|
|
}
|
|
|
|
#endif
|