Carp
Carp copied to clipboard
References must keep track of their origin
Currently, references can be invalidated by invalidating their origin inside their scope.
(defn use-up [x] ())
(defn main []
(let-do [a [@"hi"]
n (Array.nth &a 0)]
(use-up a)
(println* n))) ; we used a already! this is bad!
It is also possible to set references to point to values in a more short-lived scope:
(defn main []
(let-do [x ""]
(let [a [@"hi"]]
(set! x (Array.nth &a 0)))
(println* x))) ; a was already dropped!
Both of these can be prevented by checking the origin of a reference and whether the origin scope still exists; an error could be emitted if it doesn’t.
Cheers
The compiler now cathes this error properly.
Or actually only the first one is caught (missed that there were a second one). So this will have to be fixed still...
I think the second one requires the fixes I'm working on in the sets-of-lifetimes branch.