require'delegate'

Delegator

This library provides three different ways to delegate method calls to an object. The easiest to use is SimpleDelegator. Pass an object to the constructor and all methods supported by the object will be delegated. This object can be changed later.

Going a step further, the top level DelegateClass method allows you to easily setup delegation through class inheritance. This is considerably more flexible and thus probably the most common use for this library.

Finally, if you need full control over the delegation scheme, you can inherit from the abstract class Delegator and customize as needed. (If you find yourself needing this control, have a look at Forwardable which is also in the standard library. It may suit your needs better.)

SimpleDelegator’s implementation serves as a nice example of the use of Delegator:

classSimpleDelegator<Delegatordef__getobj__@delegate_sd_obj# return object we are delegating to, requiredenddef__setobj__(obj)@delegate_sd_obj=obj# change delegation object,# a feature we're providingendend

Notes

Be advised, RDoc will not detect delegated methods.

Delegator Reference

SimpleDelegator

A concrete implementation of Delegator, this class provides the means to delegate all supported method calls to the object passed into the constructor and even to change the object being delegated to at a later time with #__setobj__.

classUserdefborn_onDate.new(1989,9,10)endendclassUserDecorator<SimpleDelegatordefbirth_yearborn_on.yearendenddecorated_user=UserDecorator.new(User.new)decorated_user.birth_year#=> 1989decorated_user.__getobj__#=> #<User: ...>

A SimpleDelegator instance can take advantage of the fact that SimpleDelegator is a subclass of Delegator to call super to have methods called on the object being delegated to.

classSuperArray<SimpleDelegatordef[](*args)super+1endendSuperArray.new([1])[0]#=> 2

Here’s a simple example that takes advantage of the fact that SimpleDelegator’s delegation object can be changed at any time.

classStatsdefinitialize@source=SimpleDelegator.new([])enddefstats(records)@source.__setobj__(records)"Elements: #{@source.size}\n"+" Non-Nil: #{@source.compact.size}\n"+" Unique: #{@source.uniq.size}\n"endends=Stats.newputss.stats(%w{James Edward Gray II})putsputss.stats([1,2,3,nil,4,5,1,2])

Prints:

Elements: 4 Non-Nil: 4 Unique: 4 Elements: 8 Non-Nil: 7 Unique: 6 

SimpleDelegator Reference

close