X-Git-Url: https://git.realraum.at/?a=blobdiff_plain;f=go%2Fr3-eventbroker_zmq%2Fzeromq.go;h=a3d6b028fc7afba59aed9774e4eba6cd6a685076;hb=1d8fb65664abbfeec8999b5c82c6883f58db77f7;hp=e13e6f8a16ce2813747d40eedf6e4850f6d7f525;hpb=237458a36b6c7f5014d9ee61b816a61ebdc5b57d;p=svn42.git diff --git a/go/r3-eventbroker_zmq/zeromq.go b/go/r3-eventbroker_zmq/zeromq.go index e13e6f8..a3d6b02 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) @@ -91,6 +109,26 @@ func ZmqsRequestAnswer(sock *zmq.Socket, request [][]byte) (answer [][]byte) { return parts } +func ZmqsAskQuestionsAndClose(ctx *zmq.Context, addr string, questions [][][]byte) [][][]byte { + if len(addr) == 0 || ctx == nil { return nil } + + req_sock, err := ctx.Socket(zmq.Req) + if err != nil { + return nil + } + defer req_sock.Close() + + if err = req_sock.Connect(addr); err != nil { + return nil + } + + rv := make([][][]byte, len(questions)) + for index, q := range(questions) { + rv[index] = ZmqsRequestAnswer(req_sock, q) + } + return rv +} + func LookupCardIdNick(s *zmq.Socket, hexbytes []byte) (string, error) { answ := ZmqsRequestAnswer(s, [][]byte{hexbytes}) if len(answ) == 0 {