EuropaTools/include/europa/util/UniqueArray.hpp

82 lines
1.5 KiB
C++
Raw Normal View History

//
// EuropaTools
//
// (C) 2021-2025 modeco80 <lily.modeco80@protonmail.ch>
//
// SPDX-License-Identifier: MIT
//
#pragma once
#include <cstddef>
#include <memory>
namespace europa::util {
/// A little ergonomic wrapper over
/// std::unique_ptr<T[]> for buffers
/// that need to track their size as well.
template <class T>
struct UniqueArray final {
UniqueArray() = default;
explicit UniqueArray(std::size_t size) {
Resize(size);
}
UniqueArray(const UniqueArray&) = delete;
UniqueArray(UniqueArray&& move) {
array = std::move(move.array);
size = move.size;
// invalidate moved-from array to default state
move.array = nullptr;
move.size = 0;
}
UniqueArray& operator=(UniqueArray&& move) {
array = std::move(move.array);
size = move.size;
// invalidate moved-from array to default state
move.array = nullptr;
move.size = 0;
2025-01-17 23:11:14 -05:00
return *this;
}
void Resize(std::size_t size) {
this->array = std::make_unique<T[]>(size);
this->size = size;
}
/// Clears this array.
void Clear() {
this->array.reset();
this->size = 0;
}
T& operator[](std::size_t index) {
return (array.get())[index];
}
const T& operator[](std::size_t index) const {
return (array.get())[index];
}
T* Data() {
return array.get();
}
const T* Data() const {
return array.get();
}
std::size_t Size() const {
return size;
}
private:
std::unique_ptr<T[]> array {};
std::size_t size {};
};
} // namespace europa::util