node package manager


Forwarding of messages to different objects (mostly properties of the receiver)

forwarder for Javascript

A Forwarder (Delegator for those who are not too much purist on this question) for Javascript.

Special support for Coffeescript classes.

ForwarderJS is highly inspired by Forwarder19 for Ruby.

  { forward } = require 'forwarder'
  obj =
    name: "no name so far"
  forward obj, 'split', to: 'name'
  obj.split " " # --> ['no', 'name', 'so', 'far']
  forward obj, 'seperate', to: 'name', as: 'split'
  obj.seperate " " # --> ['no', 'name', 'so', 'far']
  forward obj, 'tokenize', to: 'name', as: 'split', with: [' ']
  obj.tokenize() # --> ['no', 'name', 'so', 'far']
  {Forwarder} = require 'forwarder'
  class F extends Forwarder
    constructor: ->
      @name = "no name so far"
      @forward 'split', to: "name"

But when forwarding to a method it is called and the return value of that call is used as the target (the same is valid in case of any function property that is the target of forwarding).

      # assuming a reverse function property
      @forward 'reverse', to: 'designation'
    designation: -> "Data"
    (new F).reverse() # --> "ataD"

Alternatively one can use forwarder on instances without extending the class of course, we will just specify this explicitely.

  { forward } = require "forwarder"
  class F
    constructor: ->
      @name = "no name so far"
      forward @, 'split', to: "name"

Same behavior as above

This is equivalent to the to\_hash special target in the Ruby version, it allows us to access object properties. Currying might be particulary interesting in this context

     obj =
         a: 42
         b: 43
       forward obj, "a", to: "content", as: "[]", with: "a"
       obj.a() # --> 42
       forward obj, "get", to: "content", as: "[]"
       obj.get('b') # --> 43

N.B. This might be missleading for beginners, [] is not a function in Javascript. I am mimicking this behavior here as it is a convenient way to implement accessors to objects.