From d5a174a6d4f8be5e7cffe7c2adbb8db23b578f56 Mon Sep 17 00:00:00 2001 From: Dominick Allen Date: Thu, 2 Jan 2025 18:49:56 -0600 Subject: Fixing errors in Vector. --- include/fud_vector.hpp | 35 ++++++++++++++++++++++++++++++++++- 1 file changed, 34 insertions(+), 1 deletion(-) (limited to 'include/fud_vector.hpp') diff --git a/include/fud_vector.hpp b/include/fud_vector.hpp index 2942e71..760587b 100644 --- a/include/fud_vector.hpp +++ b/include/fud_vector.hpp @@ -116,6 +116,7 @@ class Vector { } output.m_allocator = allocator; + // NOLINTNEXTLINE(cppcoreguidelines-pro-type-reinterpret-cast) output.m_data = reinterpret_cast(dataPtrResult.getOkay()); output.m_length = 0; output.m_capacity = capacity; @@ -354,6 +355,7 @@ class Vector { return dataPtrResult.takeError(); } + // NOLINTNEXTLINE(cppcoreguidelines-pro-type-reinterpret-cast) auto* dataPtr = reinterpret_cast(dataPtrResult.takeOkay()); for (size_t index = 0; index < m_length; ++index) { const auto* ptr = new (dataPtr + index) T(std::move(m_data[index])); @@ -363,6 +365,7 @@ class Vector { auto status = FudStatus::Success; if (m_capacity > 0) { + // NOLINTNEXTLINE(cppcoreguidelines-pro-type-reinterpret-cast) m_allocator->deallocate(reinterpret_cast(m_data), m_capacity); } @@ -645,7 +648,9 @@ class Vector { } if (m_length + Size > m_capacity) { - auto status = grow(); + size_t currentLength = m_length; + auto status = resize(m_length + Size); + m_length = currentLength; if (status != FudStatus::Success) { return status; } @@ -660,6 +665,33 @@ class Vector { return FudStatus::Success; } + FudStatus extend(Span span) + { + if (span.data() == nullptr) { + return FudStatus::NullPointer; + } + if (std::numeric_limits::max() - span.size() < m_length) { + return FudStatus::Failure; + } + if (m_length + span.size() > m_capacity) + { + size_t currentLength = m_length; + auto status = resize(m_length + span.size()); + m_length = currentLength; + if (status != FudStatus::Success) { + return status; + } + } + + for (size_t spanIndex = 0; spanIndex < span.size(); ++spanIndex) { + const auto* ptr = new (m_data + m_length) T(span[spanIndex]); + fudAssert(ptr != nullptr); + m_length++; + } + + return FudStatus::Success; + } + FudStatus erase(size_t index) { if (index >= m_length) { @@ -709,6 +741,7 @@ class Vector { auto status = clear(); if (m_data != nullptr && m_allocator != nullptr) { + // NOLINTNEXTLINE(cppcoreguidelines-pro-type-reinterpret-cast) m_allocator->deallocate(reinterpret_cast(m_data), m_capacity); } -- cgit v1.2.3