-
Notifications
You must be signed in to change notification settings - Fork 8
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
Implement reference counting #54
Comments
One thing to consider is that you still have to handle cyclical references somehow. |
I am trying to think of a PureScript program that would result in cyclic references, do you have an example on top of your head? |
Cyclical references require mutation, so it can be done with |
So a |
The cycle depends on the implementation of xs = defer \_ -> cons 42 xs This will be a single cons node that points back to itself. |
You can tie knots with Ref mutation.
|
Thank you for elaborating on this. Given they both require mutation (and therefore FFI), I doubt we can statically pick up on those. I wonder if going hybrid would be possible, such that FFI allocated values could be gc-allocated or require an explicit release function be called on them. |
I haven't read it yet, but collecting cycles seems to be a solved problem as well: https://researcher.watson.ibm.com/researcher/files/us-bacon/Bacon01Concurrent.pdf. From a bit of research many languages take this approach - python and php to name a prominent few. |
This feature has been completed! 🎉 I am very happy with the state of the project now. All packages featured in the bundled package-set build fine and their test suits run fine without leaking. Additionally, all upstream tests are passing incl. leak checks. In addition to the reference counting GC it's also possible to alternatively enable the tracing GC instead if required. The resulting binaries are small and perform at least on par with the JS equivalent. There's undoubtedly more optimizations that could be done, at the corefn level, the support library level and code-gen level, but so far the code is reasonably optimized and performing well enough for this to be a useful backend. |
Congrats! |
Experimental: Implement reference counting as an alternative or as a complement to GC.
refcount
int topurs_any_t
retain
function to incrementrefcount
(we can worry about atomicity later)release
function decrement therefcount
refcount
drops to zero clean up the containedpurs_value_t
, and free the pointerpurs_vec_t
to properly increment/decrement the reference countpurs_record_t
to properly increment/decrement the reference countretain
-ed references in scope structsretain
-ed references in_FFI
scopes (andrelease
afterBODY
)release
calls for allocated resources before returning from functionsThe text was updated successfully, but these errors were encountered: