From: "rosenfeld (Rodrigo Rosenfeld Rosas)" Date: 2013-02-19T22:54:46+09:00 Subject: [ruby-core:52525] [ruby-trunk - Feature #7882] Allow rescue/else/ensure in do..end Issue #7882 has been updated by rosenfeld (Rodrigo Rosenfeld Rosas). I don't find it that odd, Nobu, although I think most developers would tend to use do-end anyway as we usually do in Ruby when the block span multiple lines. I like the idea very much actually. ---------------------------------------- Feature #7882: Allow rescue/else/ensure in do..end https://bugs.ruby-lang.org/issues/7882#change-36615 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/