mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 02:57:44 +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:
parent
bb045b3c70
commit
f9d8e42636
1 changed files with 2 additions and 3 deletions
|
@ -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;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue