<br><br><div class="gmail_quote">On Wed, Feb 29, 2012 at 6:24 AM, Michael Foord <span dir="ltr"><<a href="mailto:fuzzyman@gmail.com">fuzzyman@gmail.com</a>></span> wrote:<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

<br><div class="gmail_quote"><div class="im">On 29 February 2012 08:23, Nick Coghlan <span dir="ltr"><<a href="mailto:ncoghlan@gmail.com" target="_blank">ncoghlan@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">


<div><br></div>
One way to handle this case is to use a separate if statement to make<br>
the flow control clear.<br>
<br>
    with cm() as run_body:<br>
        if run_body:<br>
            # Do stuff<br>
<br>
Depending on the use case, the return value from __enter__ may be a<br>
simple flag as shown, or it may be a more complex object.<br></blockquote></div><div><br><br>The trouble with this is it indents all your code an extra level. One possibility would be allowing continue in a with statement as an early exit:<br>


<br>
    with cm() as run_body:<br>
        if not run_body:<br>
            continue<br><br></div></div></blockquote><div><br></div><div>-1 on this as an early __exit__.</div><div><br></div><div>It would be context dependent.  For with statements within a loop body, a continue today continues to the next loop iteration.  Introducing this syntax would call into question what continue does... exit the with statement within the loop body?  or continue the loop (also exiting the with statement but skipping all other code in the loop body)?</div>

<div><br></div><div>for x in range(5):</div><div>  with y() as run_body:</div><div>    if not run_body:</div><div>      continue</div><div>    print x, run_body</div><div><br></div><div>Changing the existing continue semantics would break existing code and adding continue semantics to exit a context manager that care if a with is within a loop body or not seems very unwise and surprising.</div>

<div><br></div><div>-gps</div></div>