From: "nobu (Nobuyoshi Nakada)" Date: 2013-02-19T22:48:17+09:00 Subject: [ruby-core:52524] [ruby-trunk - Feature #7882] Allow rescue/else/ensure in do..end Issue #7882 has been updated by nobu (Nobuyoshi Nakada). =begin I remember I've seen the same proposal. What do you think about {} block? foo { ... rescue ... } seems odd to me a little. Or improve (({do}))...(({end})) only? =end ---------------------------------------- Feature #7882: Allow rescue/else/ensure in do..end https://bugs.ruby-lang.org/issues/7882#change-36614 Author: charliesome (Charlie Somerville) Status: Open Priority: Normal Assignee: Category: Target version: 2.1.0 =begin The keywords (({rescue})), (({else})) and (({ensure})) can be used when defining methods like so: def foo # rescue # else # ensure # end However when using a block delimited by do..end, you must use (({begin}))..(({end})) as well: foo do begin # ... rescue # ... # ... end end It would be nice to be able to drop the extra (({begin}))..(({end})) and use (({rescue})), etc. clauses directly: foo do # ... rescue # ... # ... end I cannot think of any ambiguities this syntax would cause, but please correct me if I am wrong. =end -- http://bugs.ruby-lang.org/