1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

This commit was manufactured by cvs2svn to create branch 'ruby_1_6'.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_6@1380 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
(no author) 2001-05-07 23:56:05 +00:00
parent 80538b4463
commit bc6a4d52f5
3 changed files with 259 additions and 0 deletions

84
doc/forwardable.rd Normal file
View file

@ -0,0 +1,84 @@
-- forwardable.rb
$Release Version: 1.1 $
$Revision$
$Date$
Original version by Tosh
=begin
= Forwardable
A Module to define delegations for selected methods to a class.
== Usage
Using through extending the class.
class Foo
extend Forwardable
def_delegators("@out", "printf", "print")
def_delegators(:@in, :gets)
def_delegator(:@contents, :[], "content_at")
end
f = Foo.new
f.printf ...
f.gets
f.content_at(1)
== Methods
--- Forwardable#def_instance_delegators(accessor, *methods)
adding the delegations for each method of ((|methods|)) to
((|accessor|)).
--- Forwardable#def_instance_delegator(accessor, method, ali = method)
adding the delegation for ((|method|)) to ((|accessor|)). When
you give optional argument ((|ali|)), ((|ali|)) is used as the
name of the delegation method, instead of ((|method|)).
--- Forwardable#def_delegators(accessor, *methods)
the alias of ((|Forwardable#def_instance_delegators|)).
--- Forwardable#def_delegator(accessor, method, ali = method)
the alias of ((|Forwardable#def_instance_delegator|)).
= SingleForwardable
a Module to define delegations for selected methods to an object.
== Usage
Using through extending the object.
g = Goo.new
g.extend SingleForwardable
g.def_delegator("@out", :puts)
g.puts ...
== Methods
--- SingleForwardable#def_singleton_delegators(accessor, *methods)
adding the delegations for each method of ((|methods|)) to
((|accessor|)).
--- SingleForwardable#def_singleton_delegator(accessor, method, ali = method)
adding the delegation for ((|method|)) to ((|accessor|)). When
you give optional argument ((|ali|)), ((|ali|)) is used as the
name of the delegation method, instead of ((|method|)).
--- SingleForwardable#def_delegators(accessor, *methods)
the alias of ((|SingleForwardable#def_instance_delegators|)).
--- SingleForwardable#def_delegator(accessor, method, ali = method)
the alias of ((|SingleForwardable#def_instance_delegator|)).
=end

81
doc/forwardable.rd.jp Normal file
View file

@ -0,0 +1,81 @@
-- forwatable.rb
$Release Version: 1.1 $
$Revision$
$Date$
=begin
= Forwardable
クラスに対しメソッドの委譲機能を定義します.
== 使い方
クラスに対してextendして使います.
class Foo
extend Forwardable
def_delegators("@out", "printf", "print")
def_delegators(:@in, :gets)
def_delegator(:@contents, :[], "content_at")
end
f = Foo.new
f.printf ...
f.gets
f.content_at(1)
== メソッド
--- Forwardable#def_instance_delegators(accessor, *methods)
((|methods|))で渡されたメソッドのリストを((|accessorに|))委譲する
ようにします.
--- Forwardable#def_instance_delegator(accessor, method, ali = method)
((||method|))で渡されたメソッドを((|accessor|))に委譲するようにし
ます. ((|ali|))が引数として渡されたときは, メソッド((|ali|))が呼ば
れたときには, ((|accessor|))に対し((|method|))を呼び出します.
--- Forwardable#def_delegators(accessor, *methods)
((|Forwardable#def_instance_delegators|))の別名です.
--- Forwardable#def_delegator(accessor, method, ali = method)
((|Forwardable#def_instance_delegator|))の別名です.
= SingleForwardable
オブジェクトに対し, メソッドの委譲機能を定義します.
== 使い方
オブジェクトに対して((|extend|))して使います.
g = Goo.new
g.extend SingleForwardable
g.def_delegator("@out", :puts)
g.puts ...
== メソッド
--- SingleForwardable#def_singleton_delegators(accessor, *methods)
((|methods|))で渡されたメソッドのリストを((|accessor|))に委譲する
ようにします.
--- SingleForwardable#def_singleton_delegator(accessor, method, ali = method)
((|method|))で渡されたメソッドを((|accessor|))に委譲するようにしま
す. ((|ali|))が引数として渡されたときは, メソッド((|ali|))が呼ばれ
たときには, ((|accessor|))に対し((|method|))を呼び出します.
--- SingleForwardable#def_delegators(accessor, *methods)
((|SingleForwardable#def_singleton_delegators|))の別名です.
--- SingleForwardable#def_delegator(accessor, method, ali = method)
((|SingleForwardable#def_singleton_delegator|))の別名です.
=end

94
lib/forwardable.rb Normal file
View file

@ -0,0 +1,94 @@
#
# forwardable.rb -
# $Release Version: 1.1$
# $Revision$
# $Date$
# by Keiju ISHITSUKA(keiju@ishitsuka.com)
# original definition by delegator.rb
# --
# Usage:
#
# class Foo
# extend Forwardable
#
# def_delegators("@out", "printf", "print")
# def_delegators(:@in, :gets)
# def_delegator(:@contents, :[], "content_at")
# end
# f = Foo.new
# f.printf ...
# f.gets
# f.content_at(1)
#
# g = Goo.new
# g.extend SingleForwardable
# g.def_delegator("@out", :puts)
# g.puts ...
#
#
module Forwardable
@debug = nil
class<<self
attr_accessor :debug
end
def def_instance_delegators(accessor, *methods)
for method in methods
def_instance_delegator(accessor, method)
end
end
def def_instance_delegator(accessor, method, ali = method)
accessor = accessor.id2name if accessor.kind_of?(Integer)
method = method.id2name if method.kind_of?(Integer)
ali = ali.id2name if ali.kind_of?(Integer)
module_eval(<<-EOS, "(__FORWARDABLE__)", 1)
def #{ali}(*args, &block)
begin
#{accessor}.__send__(:#{method}, *args, &block)
rescue Exception
$@.delete_if{|s| /^\\(__FORWARDABLE__\\):/ =~ s} unless Forwardable::debug
raise
end
end
EOS
end
alias def_delegators def_instance_delegators
alias def_delegator def_instance_delegator
end
module SingleForwardable
def def_singleton_delegators(accessor, *methods)
for method in methods
def_singleton_delegator(accessor, method)
end
end
def def_singleton_delegator(accessor, method, ali = method)
accessor = accessor.id2name if accessor.kind_of?(Integer)
method = method.id2name if method.kind_of?(Integer)
ali = ali.id2name if ali.kind_of?(Integer)
instance_eval(<<-EOS, "(__FORWARDABLE__)", 1)
def #{ali}(*args, &block)
begin
#{accessor}.__send__(:#{method}, *args,&block)
rescue Exception
$@.delete_if{|s| /^\\(__FORWARDABLE__\\):/ =~ s} unless Forwardable::debug
raise
end
end
EOS
end
alias def_delegators def_singleton_delegators
alias def_delegator def_singleton_delegator
end