Compare commits
No commits in common. "da805eec835bed19d21eb8f3bf3b5533eb7640a4" and "3b4b750cbf4c1d0589f45b9963eba55a2524bc06" have entirely different histories.
da805eec83
...
3b4b750cbf
@ -7,7 +7,6 @@
|
||||
#define STRINGIZE_VALUE_OF(x) STRINGIZE(x)
|
||||
#endif
|
||||
|
||||
// Like check(), but with a custom error message.
|
||||
#define expect(expr, message) \
|
||||
do { \
|
||||
if (!(expr)) [[unlikely]] \
|
||||
@ -16,7 +15,6 @@
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
// Like assert(), but always enabled.
|
||||
#define check(expr) \
|
||||
do { \
|
||||
if (!(expr)) [[unlikely]] \
|
||||
|
@ -14,60 +14,6 @@ template <typename T> class Vector
|
||||
{
|
||||
}
|
||||
|
||||
Vector(const Vector<T>& other)
|
||||
{
|
||||
reserve(other.capacity());
|
||||
memcpy(m_data, other.data(), other.size());
|
||||
m_size = other.size();
|
||||
}
|
||||
|
||||
Vector(Vector<T>&& other)
|
||||
{
|
||||
m_data = other.data();
|
||||
m_capacity = other.capacity();
|
||||
m_size = other.size();
|
||||
|
||||
other.m_capacity = other.m_size = 0;
|
||||
other.m_data = nullptr;
|
||||
}
|
||||
|
||||
Vector<T>& operator=(const Vector<T>& other)
|
||||
{
|
||||
if (&other == this) return *this;
|
||||
|
||||
if (m_data) free_impl(m_data);
|
||||
|
||||
m_data = nullptr;
|
||||
m_capacity = m_size = 0;
|
||||
|
||||
reserve(other.capacity());
|
||||
memcpy(m_data, other.data(), other.size());
|
||||
m_size = other.size();
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vector<T>& operator=(Vector<T>&& other)
|
||||
{
|
||||
if (&other == this) return *this;
|
||||
|
||||
if (m_data) free_impl(m_data);
|
||||
|
||||
m_data = other.data();
|
||||
m_capacity = other.capacity();
|
||||
m_size = other.size();
|
||||
|
||||
other.m_capacity = other.m_size = 0;
|
||||
other.m_data = nullptr;
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
~Vector()
|
||||
{
|
||||
if (m_data) free_impl(m_data);
|
||||
}
|
||||
|
||||
Result<void> try_reserve(usize capacity)
|
||||
{
|
||||
return resize(capacity);
|
||||
|
Loading…
x
Reference in New Issue
Block a user