mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
merge revision(s) 44630,44631: [Backport #9403]
* lib/delegate.rb (Delegator): keep source information methods which start and end with '__'. [ruby-core:58572] [Bug #9155] which start and end with '__'. [ruby-core:59718] [Bug #9403] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_1@44794 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
484a6ffb78
commit
3da0a0cead
4 changed files with 66 additions and 4 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
Sun Feb 2 22:39:28 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
|
* lib/delegate.rb (Delegator): keep source information methods
|
||||||
|
which start and end with '__'. [ruby-core:59718] [Bug #9403]
|
||||||
|
|
||||||
Fri Jan 31 12:10:16 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
Fri Jan 31 12:10:16 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
* proc.c (mnew_from_me): keep iclass as-is, to make inheritance
|
* proc.c (mnew_from_me): keep iclass as-is, to make inheritance
|
||||||
|
|
|
@ -48,7 +48,7 @@ class Delegator < BasicObject
|
||||||
undef_method m
|
undef_method m
|
||||||
end
|
end
|
||||||
private_instance_methods.each do |m|
|
private_instance_methods.each do |m|
|
||||||
if /\Ablock_given\?\z|iterator\?\z|\A__raise__\z/ =~ m
|
if /\Ablock_given\?\z|iterator\?\z|\A__.*__\z/ =~ m
|
||||||
next
|
next
|
||||||
end
|
end
|
||||||
undef_method m
|
undef_method m
|
||||||
|
|
|
@ -180,4 +180,61 @@ class TestDelegateClass < Test::Unit::TestCase
|
||||||
x = assert_nothing_raised(ArgumentError, bug9155) {break Bug9155.new(1)}
|
x = assert_nothing_raised(ArgumentError, bug9155) {break Bug9155.new(1)}
|
||||||
assert_equal(1, x.to_i, bug9155)
|
assert_equal(1, x.to_i, bug9155)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
class Bug9403
|
||||||
|
Name = '[ruby-core:59718] [Bug #9403]'
|
||||||
|
SD = SimpleDelegator.new(new)
|
||||||
|
class << SD
|
||||||
|
def method_name
|
||||||
|
__method__
|
||||||
|
end
|
||||||
|
def callee_name
|
||||||
|
__callee__
|
||||||
|
end
|
||||||
|
alias aliased_name callee_name
|
||||||
|
def dir_name
|
||||||
|
__dir__
|
||||||
|
end
|
||||||
|
end
|
||||||
|
dc = DelegateClass(self)
|
||||||
|
dc.class_eval do
|
||||||
|
def method_name
|
||||||
|
__method__
|
||||||
|
end
|
||||||
|
def callee_name
|
||||||
|
__callee__
|
||||||
|
end
|
||||||
|
alias aliased_name callee_name
|
||||||
|
def dir_name
|
||||||
|
__dir__
|
||||||
|
end
|
||||||
|
end
|
||||||
|
DC = dc.new(new)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_method_in_simple_delegator
|
||||||
|
assert_equal(:method_name, Bug9403::SD.method_name, Bug9403::Name)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_callee_in_simple_delegator
|
||||||
|
assert_equal(:callee_name, Bug9403::SD.callee_name, Bug9403::Name)
|
||||||
|
assert_equal(:aliased_name, Bug9403::SD.aliased_name, Bug9403::Name)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_dir_in_simple_delegator
|
||||||
|
assert_equal(__dir__, Bug9403::SD.dir_name, Bug9403::Name)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_method_in_delegator_class
|
||||||
|
assert_equal(:method_name, Bug9403::DC.method_name, Bug9403::Name)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_callee_in_delegator_class
|
||||||
|
assert_equal(:callee_name, Bug9403::DC.callee_name, Bug9403::Name)
|
||||||
|
assert_equal(:aliased_name, Bug9403::DC.aliased_name, Bug9403::Name)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_dir_in_delegator_class
|
||||||
|
assert_equal(__dir__, Bug9403::DC.dir_name, Bug9403::Name)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
#define RUBY_VERSION "2.1.1"
|
#define RUBY_VERSION "2.1.1"
|
||||||
#define RUBY_RELEASE_DATE "2014-02-01"
|
#define RUBY_RELEASE_DATE "2014-02-02"
|
||||||
#define RUBY_PATCHLEVEL 14
|
#define RUBY_PATCHLEVEL 15
|
||||||
|
|
||||||
#define RUBY_RELEASE_YEAR 2014
|
#define RUBY_RELEASE_YEAR 2014
|
||||||
#define RUBY_RELEASE_MONTH 2
|
#define RUBY_RELEASE_MONTH 2
|
||||||
#define RUBY_RELEASE_DAY 1
|
#define RUBY_RELEASE_DAY 2
|
||||||
|
|
||||||
#include "ruby/version.h"
|
#include "ruby/version.h"
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue