X-Git-Url: https://git.realraum.at/?a=blobdiff_plain;f=go%2Fr3-netstatus%2Fzeromq.go;fp=go%2Fr3-netstatus%2Fzeromq.go;h=38d1732702bd29e3afc32d51545b9ec310985da9;hb=2416b163f05370fcffb2f62bea000265d10aac42;hp=0000000000000000000000000000000000000000;hpb=db6096af35c81fac74bacda38c734a76b7bdf9c1;p=svn42.git diff --git a/go/r3-netstatus/zeromq.go b/go/r3-netstatus/zeromq.go new file mode 100644 index 0000000..38d1732 --- /dev/null +++ b/go/r3-netstatus/zeromq.go @@ -0,0 +1,47 @@ +// (c) Bernhard Tittelbach, 2013 + +package main + +import ( + zmq "github.com/vaughan0/go-zmq" + ) + +// ---------- ZeroMQ Code ------------- + +func ZmqsInit(sub_port string) (ctx *zmq.Context, sub_chans *zmq.Channels) { + var err error + ctx, err = zmq.NewContext() + if err != nil { + panic(err) + } + //close only on later panic, otherwise leave open: + defer func(){ if r:= recover(); r != nil { ctx.Close(); panic(r) } }() + + if len(sub_port) > 0 { + sub_sock, err := ctx.Socket(zmq.Sub) + if err != nil { + panic(err) + } + defer func() { if r:= recover(); r != nil { sub_sock.Close(); panic(r) } }() + + sub_sock.Subscribe([]byte{}) //subscribe empty filter -> aka to all messages + + if err = sub_sock.Connect(sub_port); err != nil { + panic(err) + } + + sub_chans = sub_sock.ChannelsBuffer(10) + go zmqsHandleError(sub_chans) + } else { + sub_chans = nil + } + + return +} + +func zmqsHandleError(chans *zmq.Channels) { + for error := range(chans.Errors()) { + chans.Close() + panic(error) + } +}