:once fn allows recur to head, possibly clearing closed overs

Description

Currently, while nonsensical, it is technically possible to `recur` to a `^:once fn*` point.

Repro:

Proposed:

If recur to head and in :once, then turn off :once and don’t clear closed overs. This allows existing code in the wild to continue to work correctly (by ignoring the :once hint in this case).

This change is being made in the context of .

Alternative:

Make this a compile error and throw if recur attempted inside :once fn

This is useful so that code like `(future (recur))` doesn't compile, giving users the impression that it's supposed to work (see comments at for an example)

Patch: 0001-CLJ-2317-disallow-recur-to-once-fn.patch

Decided not to do this as there is existing code, especially code that combines macros that make :once fns with code that may recur without knowing that.

Environment

None

Attachments

1

Activity

Show:

Alex Miller August 3, 2024 at 6:34 PM

Released in 1.11.4 and 1.12.0-rc1

Nicola Mometto January 25, 2018 at 1:59 PM

Fixed

Details

Assignee

Reporter

Approval

Ok

Patch

Code

Priority

Affects versions

Created January 25, 2018 at 1:45 PM
Updated November 1, 2024 at 5:10 PM
Resolved November 1, 2024 at 5:10 PM