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

Introduce Finalizers to avoid cycles #10

Merged
merged 2 commits into from
Aug 6, 2014
Merged

Introduce Finalizers to avoid cycles #10

merged 2 commits into from
Aug 6, 2014

Conversation

pwaller
Copy link
Collaborator

@pwaller pwaller commented Jul 28, 2014

As per #8, there was a leak due to cycles and the definition of a
__del__ destructor. This instead uses weak proxies to be notified of
deletion and invoke the correct destructor.

A new type, _BaseFinalizer is introduced, where one can override the
destruction behaviour by defining destructor.

pwaller added 2 commits July 28, 2014 13:38
As per #8, there was a leak due to cycles and the definition of a
`__del__` destructor. This instead uses weak proxies to be notified of
deletion and invoke the correct destructor.

A new type, `_BaseFinalizer` is introduced, where one can override the
destruction behaviour by defining `destructor`.
@pwaller pwaller mentioned this pull request Jul 28, 2014
lazka added a commit that referenced this pull request Aug 6, 2014
Introduce Finalizers to avoid cycles
@lazka lazka merged commit 425be9e into master Aug 6, 2014
@lazka
Copy link
Member

lazka commented Aug 6, 2014

Sorry for the delay. Thanks for this.

btw. "./setup.py quality" will run pep8/pyflakes tests from https://github.com/lazka/pgi/tree/master/tests/misc

It can be a bit annoying, but it makes sure the code is tidy.

@pwaller pwaller deleted the finalizer branch August 6, 2014 09:28
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

Successfully merging this pull request may close these issues.

2 participants