Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Destructor in Sprite Library missing #17

Open
jayseeee opened this issue May 25, 2012 · 4 comments
Open

Destructor in Sprite Library missing #17

jayseeee opened this issue May 25, 2012 · 4 comments
Assignees

Comments

@jayseeee
Copy link

The destructor is missing in the sprite library (and also in the matrix library) which leads to a memory leak when dynamically creating sprites. When adding a destructor it becomes necessary to add a copy and an assignment operator.

The following addtions should be made to the sprite library:

Sprite::Sprite(const Sprite &other)
{
operator=(other); // Call the assignment operator
}

Sprite::~Sprite()
{
if (!_buffer) return;
free(_buffer); // Make sure to free the buffer if it exists
}

Sprite& Sprite::operator=(const Sprite &other)
{
_width = other._width;
_height = other._height;
init(_width, _height);
memcpy(_buffer,other._buffer,_height);
return *this;
}

Kind regards,

Jean-Claude

@jayseeee
Copy link
Author

Already reported this bug on google code but it did not get fixed yet.

@AlexanderBrevig
Copy link
Member

Have you verified that the destructor gets called? I seem to remember that the current implementation of delete does not call destructors? Let me know and I'll fix this problem if the destructors actually gets called. (Either way I think I'll fix this, just because it's good practice.)
PS: Maybe I'm confusing this with virtual destructors?

@jayseeee
Copy link
Author

Dear Alexander, I verified that the destructor gets called! Delete always calls the destructor. Can be a problem when using derived classes and pointers to this derived classes in which case you have to define a virtual destructor as explained in: http://www.programmerinterview.com/index.php/c-cplusplus/virtual-destructors/

@AlexanderBrevig
Copy link
Member

With the new tool chain I think we're ready to support virtual destructors, as a note to self: Remember to define
int __cxa_guard_acquire(__guard g) {return !(char )(g);};
void __cxa_guard_release (__guard *g) {
(char *)g = 1;};
void __cxa_guard_abort (__guard *) {};
void __cxa_pure_virtual(void) {};

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants