1
0
Fork 0
shezmu/caller
Gregory Eremin 777ff5a09b Caller now accepts any unmarshal functions; JSON is used by default 2015-10-17 01:08:14 +03:00
..
README.md Use new name 2015-10-14 03:50:43 +03:00
caller.go Caller now accepts any unmarshal functions; JSON is used by default 2015-10-17 01:08:14 +03:00
caller_test.go Caller now accepts any unmarshal functions; JSON is used by default 2015-10-17 01:08:14 +03:00

README.md

Caller

Package caller is used to dynamically call functions with data unmarshalled into the functions' first argument. Its main purpose is to hide common unmarshalling code from each function implementation thus reducing boilerplate and making package interaction code sexier.

Documentation

Example

package main

import (
    "log"
    "github.com/localhots/satan/caller"
    "github.com/path/to/package/messenger"
)

type PriceUpdate struct {
    Product string  `json:"product"`
    Amount  float32 `json:"amount"`
}

func main() {
    messenger.Subscribe("ProductPriceUpdates", func(p PriceUpdate) {
        log.Printf("Price for %q is now $%.2f", p.Product, p.Amount)
    })
    messenger.Deliver()
}

Support code:

package messenger

import (
    "github.com/localhots/satan/caller"
)

type item struct {
    topic   string
    payload []byte
}

var queue <-chan item
var subscriptions = make(map[string][]*caller.Caller)

func Subscribe(topic string, callback interface{}) {
    c, err := caller.New(processMessage)
    if err != nil {
        panic(err)
    }
    subcriptions[topic] = append(subcriptions[topic], c)
}

func Deliver() {
    for itm := range queue {
        for _, c := range subscriptions[itm.topic] {
            // Payload example:
            // {"product": "Paperclip", "amount": 0.01}
            c.Call(itm.payload)
        }
    }
}