1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-27 23:17:45 +00:00

LibVideo: Allocate Vector2D underlying storage with new, not malloc

Using malloc does not invoke T's constructor, nor were were invoking T's
constructor ourselves. Accessing T without invoking its constructor is
undefined behavior.
This commit is contained in:
Timothy Flynn 2023-04-24 12:47:15 -04:00 committed by Andrew Kaster
parent bb045b3c70
commit f9d8e42636

View file

@ -112,7 +112,7 @@ public:
clear_storage();
size_t size = height * width;
auto* new_storage = static_cast<T*>(malloc(size * sizeof(T)));
auto* new_storage = new (nothrow) T[size];
if (!new_storage)
return Error::from_errno(ENOMEM);
m_storage = new_storage;
@ -194,8 +194,7 @@ public:
private:
void clear_storage()
{
if (m_storage)
free(m_storage);
delete[] m_storage;
m_storage = nullptr;
m_width = 0;
m_height = 0;