in reply to Re^2: "next" from within eval {} ?
in thread "next" from within eval {} ?

I would be interested to read you expound upon this aside.

My thinking was:

For warn, a true return value enables structures such as warn "Loop failure\n" and next if $_ eq "bad"; that I feel (YMMV) are quite natural.

I also like the way warn ... and next reads, and have used it extensively. But, it is logically incorrect.

The next is not logically dependant upon the success of warn, and should not be made so.

In the unlikely event that warn failed, the next would not be actioned and the wrong action would result.

It should be -- and when I remember, I now code it as -- warn(...), next. Many people don't like the comma operator, but those same people probably wouldn't use warn and next either.

Now to why the though came up in my previous post. This:

for (1..5) { print if eval{ do_foo() && do_bar() } or warn $@; }

Would be cleaner than:

for (1..5) { print if eval{ do_foo() && do_bar() } or do{ warn $@; 0 }; }

but currently would do the wrong thing.

Of course, it is too late now, but that doesn't detract from the notion that a failure return from warn is pretty useless.


With the rise and rise of 'Social' network sites: 'Computers are making people easier to use everyday'
Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
"Science is about questioning the status quo. Questioning authority".
In the absence of evidence, opinion is indistinguishable from prejudice.

The start of some sanity?