#pragma once #include "matrix.hpp" template Matrix::Matrix(const Bounds &bounds) noexcept : _matrix(new Element *[bounds.get_height()]), _row_cnt(bounds.get_height()), _column_cnt(bounds.get_width()) { for (gsl::owner row = _matrix; row != _matrix + _row_cnt; row++) { *row = static_cast>(new Element[bounds.get_width()]); } }; template Matrix::Matrix(const Matrix &matrix) noexcept : _matrix(new Element *[matrix._row_cnt]), _row_cnt(matrix._row_cnt), _column_cnt(matrix._column_cnt) { _copy_matrix_from(matrix); } template Matrix::Matrix(Matrix &&matrix) noexcept : _matrix(matrix._matrix), _row_cnt(matrix._row_cnt), _column_cnt(matrix._column_cnt) { matrix._matrix = nullptr; } template Matrix::~Matrix() noexcept { _delete_matrix(); } template void Matrix::fill(Element element) noexcept { for (auto row : *this) { for (auto &col : row) { col = element; } } } template auto Matrix::get(const Vector2 &pos) const noexcept -> Element { auto x = static_cast(pos.get_x()); auto y = static_cast(pos.get_y()); // NOLINTNEXTLINE(cppcoreguidelines-pro-bounds-pointer-arithmetic) return _matrix[y][x]; } template void Matrix::set(const Vector2 &pos, Element element) noexcept { auto x = static_cast(pos.get_x()); auto y = static_cast(pos.get_y()); // NOLINTNEXTLINE(cppcoreguidelines-pro-bounds-pointer-arithmetic) _matrix[y][x] = element; } template auto Matrix::get_row_cnt() const noexcept -> std::uint32_t { return _row_cnt; } template auto Matrix::get_column_cnt() const noexcept -> std::uint32_t { return _column_cnt; } template auto Matrix::get_size() const noexcept -> Bounds { return Bounds({.width = _column_cnt, .height = _row_cnt}); } template auto Matrix::begin() const noexcept -> MatrixIterator { return MatrixIterator(_matrix, _column_cnt); } template auto Matrix::end() const noexcept -> MatrixIterator { return MatrixIterator(_matrix + _row_cnt, _column_cnt); } template auto Matrix::operator=(const Matrix &rhs) noexcept -> Matrix & { if (&rhs != this) { _delete_matrix(); // NOLINTNEXTLINE(cppcoreguidelines-owning-memory) _matrix = nullptr; _matrix = new Element *[rhs._row_cnt]; _copy_matrix_from(rhs); } return *this; } template auto Matrix::operator=(Matrix &&rhs) noexcept -> Matrix & { if (&rhs != this) { _delete_matrix(); // NOLINTNEXTLINE(cppcoreguidelines-owning-memory) _matrix = rhs._matrix; rhs._matrix = nullptr; } return *this; } template void Matrix::_delete_matrix() noexcept { for (gsl::owner row = _matrix; row != _matrix + _row_cnt; row++) { delete[](*row); } delete[] _matrix; } template void Matrix::_copy_matrix_from(const Matrix &source) noexcept { // NOLINTNEXTLINE(cppcoreguidelines-owning-memory) gsl::owner source_row = source._matrix; for (gsl::owner row = _matrix; row != _matrix + _row_cnt; row++, source_row++) { *row = static_cast>(new Element[_column_cnt]); // NOLINTNEXTLINE(cppcoreguidelines-pro-bounds-pointer-arithmetic) auto *end = *source_row + _column_cnt; std::copy(*source_row, end, *row); } }