<div dir="ltr"><div>Dear Spec Experts,</div><div><br></div><div>There is a (small) language change under consideration on amber-dev, and opinions have been expressed in multiple directions, so I'm turning to this list for hopefully some authoritative adjudication.</div><div><div><div><br></div></div><div>The idea is: allow loop variables declared in basic (old 
style) for() loops to be captured in the body of the loop as long as 
they are not reassigned in the body of the loop, even though they might be 
reassigned in the loop step:</div><div style="margin-left:40px"><pre><span>for</span> (<span>int</span> <span>i</span> = <span>1</span>; <span>i</span> <= <span>3</span>; <span>i</span>++) {
    <span>Runnable</span> <span>r</span> = () -> <span>System</span>.<span>out</span>.<span>println</span>(i);   // allow this
}</pre></div></div><div>Long discussion starts here (continues into October): <a href="https://mail.openjdk.org/pipermail/amber-dev/2024-September/008921.html">https://mail.openjdk.org/pipermail/amber-dev/2024-September/008921.html</a></div><div><br><div>Here's what has been drafted so far (all subject to improvement of course):<br></div><div><div class="gmail-adm"><div id="gmail-q_4765" class="gmail-ajR gmail-h4" aria-label="Hide expanded content" aria-expanded="true"><div class="gmail-ajT"></div></div></div><div class="gmail-im"><div><br></div><div>Bug: <a href="https://bugs.openjdk.org/browse/JDK-8341782" target="_blank">https://bugs.openjdk.org/browse/JDK-8341782</a></div><div>CSR: <a href="https://bugs.openjdk.org/browse/JDK-8341783" target="_blank">https://bugs.openjdk.org/browse/JDK-8341783</a><br>JEP: <a href="https://bugs.openjdk.org/browse/JDK-8341785" target="_blank">https://bugs.openjdk.org/browse/JDK-8341785</a><br>JLS: <a href="https://bugs.openjdk.org/browse/JDK-8341786" target="_blank">https://bugs.openjdk.org/browse/JDK-8341786</a><br>PR: <a href="https://github.com/openjdk/jdk/pull/21415" target="_blank">https://github.com/openjdk/jdk/pull/21415</a></div><br></div></div></div><div>Just to be clear, I know it looks like I've got a lot personally invested in this, but honestly I don't care about the outcome. Yes I think this would be a nice tweak, but it's not my decision. Instead, the items listed above are there to create a tangible basis for making such a decision. I am really just trying to knock this item off my to-do list one way or the other (scrubbing the to-do list is a favorite year-end activity).<br></div><div><div><br></div><div>Let me know your collective thoughts, ideally one of: ▢ Proceed ▢ Reject ▢ Shelve it for later<br></div><div><br></div></div><div>Thanks!</div><div>-Archie</div><div><br></div><span class="gmail_signature_prefix">-- </span><br><div dir="ltr" class="gmail_signature" data-smartmail="gmail_signature">Archie L. Cobbs<br></div><div><br></div></div>