Carp icon indicating copy to clipboard operation
Carp copied to clipboard

References must keep track of their origin

Open hellerve opened this issue 6 years ago • 4 comments

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

hellerve avatar May 29 '19 07:05 hellerve

The compiler now cathes this error properly.

eriksvedang avatar Apr 30 '20 12:04 eriksvedang

Or actually only the first one is caught (missed that there were a second one). So this will have to be fixed still...

eriksvedang avatar Apr 30 '20 12:04 eriksvedang

I think the second one requires the fixes I'm working on in the sets-of-lifetimes branch.

eriksvedang avatar May 06 '20 13:05 eriksvedang