2015-11-13 17:17:37 +11:00
|
|
|
/*
|
|
|
|
* 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>
|
|
|
|
*/
|
|
|
|
|
2017-08-29 16:53:11 +10:00
|
|
|
#ifndef CRUFT_UTIL_ALLOC_RAW_LINEAR_HPP
|
|
|
|
#define CRUFT_UTIL_ALLOC_RAW_LINEAR_HPP
|
2015-11-13 17:17:37 +11:00
|
|
|
|
|
|
|
#include <cstddef>
|
2017-08-30 15:13:43 +10:00
|
|
|
#include <iterator>
|
2015-11-13 17:17:37 +11:00
|
|
|
|
2017-08-29 16:53:11 +10:00
|
|
|
namespace util::alloc::raw {
|
2015-11-19 15:03:57 +11:00
|
|
|
// allocate progressively across a buffer without concern for deallocation.
|
|
|
|
// deallocation is a noop; the only way to free allocations is via reset.
|
2015-11-13 17:17:37 +11:00
|
|
|
class linear {
|
|
|
|
public:
|
|
|
|
linear (const linear&) = delete;
|
|
|
|
linear (linear&&) = delete;
|
|
|
|
linear& operator= (const linear&) = delete;
|
|
|
|
linear& operator= (linear&&) = delete;
|
|
|
|
|
|
|
|
linear (void *begin, void *end);
|
|
|
|
|
2017-08-30 15:13:43 +10:00
|
|
|
template <typename T>
|
|
|
|
linear (T &&view):
|
|
|
|
linear (std::begin (view), std::end (view))
|
|
|
|
{ ; }
|
|
|
|
|
2016-10-10 20:59:26 +11:00
|
|
|
void* allocate (size_t bytes);
|
|
|
|
void* allocate (size_t bytes, size_t alignment);
|
|
|
|
|
|
|
|
void deallocate (void *ptr, size_t bytes);
|
|
|
|
void deallocate (void *ptr, size_t bytes, size_t alignment);
|
|
|
|
|
2018-02-28 17:55:56 +11:00
|
|
|
std::byte* data (void);
|
|
|
|
std::byte* begin (void);
|
|
|
|
std::byte* end (void);
|
|
|
|
std::byte* cursor (void);
|
2017-08-31 13:48:33 +10:00
|
|
|
|
2018-02-28 17:55:56 +11:00
|
|
|
const std::byte* data (void) const;
|
|
|
|
const std::byte* begin (void) const;
|
|
|
|
const std::byte* end (void) const;
|
|
|
|
const std::byte* cursor (void) const;
|
2017-08-31 13:48:33 +10:00
|
|
|
|
2016-06-22 19:51:18 +10:00
|
|
|
size_t offset (const void*) const;
|
2015-11-13 17:17:37 +11:00
|
|
|
|
|
|
|
void reset (void);
|
|
|
|
|
|
|
|
size_t capacity (void) const;
|
2015-11-30 16:08:07 +11:00
|
|
|
size_t used (void) const;
|
2015-11-24 16:48:46 +11:00
|
|
|
size_t remain (void) const;
|
2015-11-13 17:17:37 +11:00
|
|
|
|
|
|
|
protected:
|
2018-02-28 17:55:56 +11:00
|
|
|
std::byte *const m_begin;
|
|
|
|
std::byte *const m_end;
|
|
|
|
std::byte *m_cursor;
|
2015-11-13 17:17:37 +11:00
|
|
|
};
|
2016-10-10 17:58:59 +11:00
|
|
|
}
|
2015-11-13 17:17:37 +11:00
|
|
|
|
|
|
|
#endif
|