X-Git-Url: https://git.realraum.at/?p=svn42.git;a=blobdiff_plain;f=go%2Fr3-eventbroker_zmq%2Fzeromq.go;h=81952c95b1edd800301a145795cab5e2dfcf1d8c;hp=e13e6f8a16ce2813747d40eedf6e4850f6d7f525;hb=ff98cdc53bc87b9d4f3215df248c188a84cb2fb1;hpb=2416b163f05370fcffb2f62bea000265d10aac42 diff --git a/go/r3-eventbroker_zmq/zeromq.go b/go/r3-eventbroker_zmq/zeromq.go index e13e6f8..81952c9 100644 --- a/go/r3-eventbroker_zmq/zeromq.go +++ b/go/r3-eventbroker_zmq/zeromq.go @@ -80,6 +80,24 @@ func zmqsHandleError(chans *zmq.Channels) { } } +func ZmqsBindNewReplySocket(ctx *zmq.Context, addr string) (chans *zmq.Channels, err error) { + if len(addr) == 0 { + return nil, errors.New("No listen address given") + } + sock, err := ctx.Socket(zmq.Rep) + if err != nil { return nil, err} + + if err = sock.Bind(addr); err != nil { + sock.Close() + return nil, err + } + + chans = sock.ChannelsBuffer(10) + go zmqsHandleError(chans) + + return chans, nil +} + func ZmqsRequestAnswer(sock *zmq.Socket, request [][]byte) (answer [][]byte) { if err := sock.Send(request); err != nil { panic(err)