zhangmeng
2019-08-27 fa924718b1e8d5f566f7655807e77df1bcfe8f86
nng.go
@@ -21,26 +21,21 @@
   "nanomsg.org/go-mangos/transport/all"
)
// type deliver
type td int
const (
   agent = td(iota)
   coactee
)
// NNG mangos wrap
type NNG struct {
   sock   mangos.Socket
   server bool
   mode   Mode
   url    string
   sock mangos.Socket
   typ  td
   mode Mode
   url  string
   arguments []interface{}
}
// Send impl interface Diliver
func (n *NNG) Send(data []byte) error {
   if n == nil {
      return errors.New("please init NNG first")
   }
   var err error
   if n.sock == nil {
      n.sock, err = n.makeNNG(agent)
@@ -62,6 +57,10 @@
// Recv impl interface Diliver
func (n *NNG) Recv() ([]byte, error) {
   if n == nil {
      return nil, errors.New("please init NNG first")
   }
   var err error
   if n.sock == nil {
@@ -80,9 +79,15 @@
}
// Recv2 impl interface
func (n *NNG) Recv2(data []byte) (l int, err error) {
   data, err = n.Recv()
   return len(data), err
}
// Close impl interface Deliver
func (n *NNG) Close() {
   if n.sock != nil {
   if n != nil && n.sock != nil {
      n.sock.Close()
      n.sock = nil
   }
@@ -93,7 +98,7 @@
   rmExistedIpcName(url)
   return &NNG{
      server:    true,
      typ:       agent,
      mode:      m,
      url:       url,
      arguments: args,
@@ -103,7 +108,7 @@
func nngClient(m Mode, url string, args ...interface{}) *NNG {
   return &NNG{
      server:    false,
      typ:       coactee,
      mode:      m,
      url:       url,
      arguments: args,
@@ -128,7 +133,7 @@
   switch n.mode {
   case Bus:
      sock, err = n.busMakeNNG(typ)
   case ReqRep:
   case ReqRep, SurvResp:
      sock, err = n.rrMakeNNG(typ)
   default:
      sock, err = n.ppMakeNNG(typ)