method

delegate_missing_to

Importance_2
v6.1.7.7 - Show latest stable - 0 notes - Class: Module
delegate_missing_to(target, allow_nil: nil) public

When building decorators, a common pattern may emerge:

class Partition def initialize(event) @event = event end def person detail.person || creator end private def respond_to_missing?(name, include_private = false) @event.respond_to?(name, include_private) end def method_missing(method, *args, &block) @event.send(method, *args, &block) end end 

With Module#delegate_missing_to, the above is condensed to:

class Partition delegate_missing_to :@event def initialize(event) @event = event end def person detail.person || creator end end 

The target can be anything callable within the object, e.g. instance variables, methods, constants, etc.

The delegated method must be public on the target, otherwise it will raise DelegationError. If you wish to instead return nil, use the :allow_nil option.

The marshal_dump and _dump methods are exempt from delegation due to possible interference when calling Marshal.dump(object), should the delegation target method of object add or remove instance variables.

Show source
Register or log in to add new notes.