[#46105] [ruby-trunk - Feature #6687][Open] Enumerable#with — "merborne (kyo endo)" <redmine@...>

14 messages 2012/07/02

[#46133] [ruby-trunk - Feature #6688][Open] Object#replace — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

24 messages 2012/07/03

[#46160] [ruby-trunk - Feature #6693][Open] Don't warn for unused variables starting with _ — "marcandre (Marc-Andre Lafortune)" <ruby-core@...>

15 messages 2012/07/04

[#46200] [ruby-trunk - Bug #6702][Open] Date should be either required or not — "rosenfeld (Rodrigo Rosenfeld Rosas)" <rr.rosas@...>

14 messages 2012/07/05

[#46296] [ruby-trunk - Feature #6717][Open] Method like #instance_eval that returns self (like #tap) — "alexeymuranov (Alexey Muranov)" <redmine@...>

10 messages 2012/07/10

[#46320] [ruby-trunk - Feature #6721][Open] Object#yield_self — "alexeymuranov (Alexey Muranov)" <redmine@...>

25 messages 2012/07/11

[#46339] [ruby-trunk - Bug #6724][Open] waaaaaaant! ( — "zenspider (Ryan Davis)" <redmine@...>

11 messages 2012/07/11

[#46377] [ruby-trunk - Feature #6727][Open] Add Array#rest (with implementation) — "duckinator (Nick Markwell)" <nick@...>

25 messages 2012/07/13

[#46492] [ruby-trunk - Feature #6737][Open] Add Hash#read and alias as #[]. — "trans (Thomas Sawyer)" <transfire@...>

12 messages 2012/07/15

[#46500] [ruby-trunk - Feature #6739][Open] One-line rescue statement should support specifying an exception class — Quintus (Marvin Gülker) <sutniuq@...>

22 messages 2012/07/15

[#46562] [ruby-trunk - Feature #6758][Open] Object#sequence — "merborne (kyo endo)" <redmine@...>

19 messages 2012/07/20

[#46574] [ruby-trunk - Feature #6762][Open] Control interrupt timing — "ko1 (Koichi Sasada)" <redmine@...>

39 messages 2012/07/20

[#46641] [ruby-trunk - Bug #6780][Open] cannot compile zlib module, when cross-compiling. — "jinleileiking (lei king)" <jinleileiking@...>

14 messages 2012/07/23

[#46659] [ruby-trunk - Bug #6783][Open] Infinite loop in inspect, not overriding inspect, to_s, and no known circular references. Stepping into inspect in debugger locks it up with 100% CPU. — "garysweaver (Gary Weaver)" <garysweaver@...>

8 messages 2012/07/23

[#46792] [ruby-trunk - Bug #6799][Open] Digest::*.hexdigest returns an ASCII-8BIT String — "Eregon (Benoit Daloze)" <redmine@...>

11 messages 2012/07/26

[#46799] [ruby-trunk - Feature #6801][Open] String#~ for a here document — "merborne (kyo endo)" <redmine@...>

12 messages 2012/07/27

[#46829] [ruby-trunk - Feature #6806][Open] Support functional programming: forbid instance/class variables for ModuleName::method_name, allow for ModuleName.method_name — "alexeymuranov (Alexey Muranov)" <redmine@...>

7 messages 2012/07/28

[#46832] [ruby-trunk - Bug #6807][Open] Can't compile ruby without ruby — "devcurmudgeon (Paul Sherwood)" <storitel@...>

13 messages 2012/07/28

[#46834] [ruby-trunk - Feature #6808][Open] Implicit index for enumerations — "trans (Thomas Sawyer)" <transfire@...>

15 messages 2012/07/28

[#46838] [ruby-trunk - Bug #6810][Open] `module A::B; end` is not equivalent to `module A; module B; end; end` with respect to constant lookup (scope) — "alexeymuranov (Alexey Muranov)" <redmine@...>

17 messages 2012/07/28

[#46896] (Half-baked DRAFT) new `require' framework — SASADA Koichi <ko1@...>

Hi,

22 messages 2012/07/31

[ruby-core:46702] Re: [ruby-trunk - Feature #4840] Allow returning from require

From: SASADA Koichi <ko1@...>
Date: 2012-07-24 01:37:43 UTC
List: ruby-core #46702
(2012/07/23 23:57), Rodrigo Rosenfeld Rosas wrote:
>> * "return from toplevel" should always discard the argument.
> 
> You mean "return something", right? I agree. Maybe we could even issue
> an exception if anything other than just "return" is used.
> 
>> * What's happen if it returns from the start script (the given
>>    script to interpreter as a cmdline)?
>>
>>    - The argument should be discarded; it does NOT affect the
>>      process termination status code
>>
>>    - The same as "exit", but cannot rescue SystemExit
> 
> Agreed. Specifically "return" should be equivalent to "exit 0", right?
> And "return -1" (or any other value, including 0) shouldn't be allowed
> in my opinion, raising an exception, in which case the return value
> wouldn't be 0 obviously :)

matz proposed that ignore return argument completely.  matz also said to
avoid mistake, return expression with argument (example: "return foo")
should be syntax error.


>>    - proc { return }.call in toplevel
> 
> If it is the main program, "exit" would be the equivalent. Otherwise, no
> code would be interpreted after the "call" call.
> 
> I don't understand what makes this so special.

(1)
  pr = proc{return}
  def foo(pr)
    pr.call # what happen?
  end

(1')
  1.times{
    return
  }

(2)
  # a.rb
  $pr = proc{return}

  # b.rb
  require './a.rb'
  $pr.call # waht happen?

(3)
  begin
    ...
  rescue
    return
  ensure
    return
  end

matz proposed that "accept return on toplevel (not in block, classes, etc)".

>> * Matz prefered "return" to "a special exception that require
>>    and load rescue",
>>
>>    - though some people (including ko1) prefered the latter.
> 
> I'm okay with raising an exception that would be rescued by require,
> require_relative and load.
> 
> Actually I guess this is the simpler approach and it fulfills all the
> real use cases I could think of in this moment.

I strongly recommended the exception approach because there are *NO*
difficult corner cases.

However, matz disagreed the exception approach because of "raise
StopLoading is too long".  It is a kind of "name is not good".

-- 
// SASADA Koichi at atdot dot net

In This Thread