Ruby 1.8.7 リファレンスマニュアル > ライブラリ一覧 > delegateライブラリ > SimpleDelegatorクラス

class SimpleDelegator + Delegator

クラスの継承リスト: SimpleDelegator < Delegator < Object < Kernel

要約

Delegator クラスを継承し、シンプルなメソッド委譲を実現した具象クラス。

委譲先に指定されたオブジェクトへメソッドの実行を委譲します。

例:

require 'delegate'

foo = Object.new
def foo.test
  p 25
end
foo2 = SimpleDelegator.new(foo)
foo2.test   # => 25

特異メソッド

new(obj) -> object

メソッドを委譲するオブジェクトの設定と、 メソッド委譲を行うためのクラスメソッドの定義を行います。

[PARAM] obj:
委譲先のオブジェクト

[SEE_ALSO] Delegator.new

インスタンスメソッド

__getobj__ -> object

委譲先のオブジェクトを返します。

[SEE_ALSO] Delegator#__getobj__

__getobj__ -> object

委譲先のオブジェクトを返します。

本メソッドは、サブクラスで再定義する必要があり、 デフォルトでは NotImplementedError が発生します。

[EXCEPTION] NotImplementedError:
サブクラスにて本メソッドが再定義されていない場合に発生します。
__setobj__(obj) -> object

委譲先のオブジェクトを obj に変更します。

メソッド委譲を行うためのクラスメソッドの再定義は行われないことに注意してください。 メソッド委譲を行うためのクラスメソッドの定義は生成時にのみ行われます。 そのため、以前の委譲先オブジェクトと obj の間で呼び出せるメソッドに違いがあった場合は、 何かしらの可能性が発生する可能性があります。

[PARAM] obj:
委譲先のオブジェクト
[RETURN]
変更後の委譲先オブジェクト
clone -> object
dup(obj) -> object

オブジェクトの複製を作成して返します。 dupの引数objについては、[ruby-list:44914]にて問題があることが報告されています。

[SEE_ALSO] Object#clone,Object#dup

marshal_dump -> object

シリアライゼーションをサポートするためにDelegator#__getobj__ が返すオブジェクトを返します。

marshal_load(obj) -> object

シリアライズされたオブジェクトから、Delegator#__getobj__ が返すオブジェクトを再現します。

[PARAM] obj:
Delegator#marshal_dumpの戻り値のコピー
method_missing(m, *args) -> object

渡されたメソッド名と引数を使って、Delegator#__getobj__ が返すオブジェクトへメソッド委譲を行います。

[PARAM] m:
メソッドの名前(シンボル)
[PARAM] args:
メソッドに渡された引数
[RETURN]
委譲先のメソッドからの返り値

[SEE_ALSO] Object#method_missing

respond_to?(m) -> bool

Delegator#__getobj__ が返すオブジェクトが メソッド m を持つとき真を返します。

[PARAM] m:
メソッド名

[SEE_ALSO] Object#respond_to?

定数

IgnoreBacktracePat -> Regexp

バックトレースで無視するパターンを返します。

class SimpleDelegator