Release 0.3.0
[govpp.git] / examples / binapi / af_packet / af_packet.ba.go
index f4e47d0..d24966a 100644 (file)
-// Code generated by GoVPP binapi-generator. DO NOT EDIT.
+// Code generated by GoVPP's binapi-generator. DO NOT EDIT.
 // source: /usr/share/vpp/api/core/af_packet.api.json
 
 /*
-Package af_packet is a generated from VPP binary API module 'af_packet'.
+Package af_packet is a generated VPP binary API for 'af_packet' module.
 
- The af_packet module consists of:
+It consists of:
+         6 enums
+         2 aliases
          8 messages
          4 services
 */
 package af_packet
 
-import api "git.fd.io/govpp.git/api"
-import bytes "bytes"
-import context "context"
-import strconv "strconv"
-import struc "github.com/lunixbochs/struc"
+import (
+       bytes "bytes"
+       context "context"
+       api "git.fd.io/govpp.git/api"
+       struc "github.com/lunixbochs/struc"
+       io "io"
+       strconv "strconv"
 
-// Reference imports to suppress errors if they are not otherwise used.
-var _ = api.RegisterMessage
-var _ = bytes.NewBuffer
-var _ = context.Background
-var _ = strconv.Itoa
-var _ = struc.Pack
-
-// This is a compile-time assertion to ensure that this generated file
-// is compatible with the GoVPP api package it is being compiled against.
-// A compilation error at this line likely means your copy of the
-// GoVPP api package needs to be updated.
-const _ = api.GoVppAPIPackageIsVersion1 // please upgrade the GoVPP api package
+       ethernet_types "git.fd.io/govpp.git/examples/ethernet_types"
+       interface_types "git.fd.io/govpp.git/examples/interface_types"
+)
 
 const (
        // ModuleName is the name of this module.
        ModuleName = "af_packet"
        // APIVersion is the API version of this module.
-       APIVersion = "1.0.0"
+       APIVersion = "2.0.0"
        // VersionCrc is the CRC of this module.
-       VersionCrc = 0x206563c
+       VersionCrc = 0xba745e20
 )
 
-/* Messages */
+type IfStatusFlags = interface_types.IfStatusFlags
+
+type IfType = interface_types.IfType
+
+type LinkDuplex = interface_types.LinkDuplex
+
+type MtuProto = interface_types.MtuProto
+
+type RxMode = interface_types.RxMode
 
-// AfPacketCreate represents VPP binary API message 'af_packet_create':
+type SubIfFlags = interface_types.SubIfFlags
+
+type InterfaceIndex = interface_types.InterfaceIndex
+
+type MacAddress = ethernet_types.MacAddress
+
+// AfPacketCreate represents VPP binary API message 'af_packet_create'.
 type AfPacketCreate struct {
-       HostIfName      []byte `struc:"[64]byte"`
-       HwAddr          []byte `struc:"[6]byte"`
-       UseRandomHwAddr uint8
+       HwAddr          MacAddress
+       UseRandomHwAddr bool
+       HostIfName      string `struc:"[64]byte"`
 }
 
-func (*AfPacketCreate) GetMessageName() string {
-       return "af_packet_create"
-}
-func (*AfPacketCreate) GetCrcString() string {
-       return "6d5d30d6"
-}
-func (*AfPacketCreate) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
+func (m *AfPacketCreate) Reset()                        { *m = AfPacketCreate{} }
+func (*AfPacketCreate) GetMessageName() string          { return "af_packet_create" }
+func (*AfPacketCreate) GetCrcString() string            { return "a190415f" }
+func (*AfPacketCreate) GetMessageType() api.MessageType { return api.RequestMessage }
 
-// AfPacketCreateReply represents VPP binary API message 'af_packet_create_reply':
+// AfPacketCreateReply represents VPP binary API message 'af_packet_create_reply'.
 type AfPacketCreateReply struct {
        Retval    int32
-       SwIfIndex uint32
+       SwIfIndex InterfaceIndex
 }
 
-func (*AfPacketCreateReply) GetMessageName() string {
-       return "af_packet_create_reply"
-}
-func (*AfPacketCreateReply) GetCrcString() string {
-       return "fda5941f"
-}
-func (*AfPacketCreateReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
+func (m *AfPacketCreateReply) Reset()                        { *m = AfPacketCreateReply{} }
+func (*AfPacketCreateReply) GetMessageName() string          { return "af_packet_create_reply" }
+func (*AfPacketCreateReply) GetCrcString() string            { return "5383d31f" }
+func (*AfPacketCreateReply) GetMessageType() api.MessageType { return api.ReplyMessage }
 
-// AfPacketDelete represents VPP binary API message 'af_packet_delete':
+// AfPacketDelete represents VPP binary API message 'af_packet_delete'.
 type AfPacketDelete struct {
-       HostIfName []byte `struc:"[64]byte"`
+       HostIfName string `struc:"[64]byte"`
 }
 
-func (*AfPacketDelete) GetMessageName() string {
-       return "af_packet_delete"
-}
-func (*AfPacketDelete) GetCrcString() string {
-       return "3efceda3"
-}
-func (*AfPacketDelete) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
+func (m *AfPacketDelete) Reset()                        { *m = AfPacketDelete{} }
+func (*AfPacketDelete) GetMessageName() string          { return "af_packet_delete" }
+func (*AfPacketDelete) GetCrcString() string            { return "863fa648" }
+func (*AfPacketDelete) GetMessageType() api.MessageType { return api.RequestMessage }
 
-// AfPacketDeleteReply represents VPP binary API message 'af_packet_delete_reply':
+// AfPacketDeleteReply represents VPP binary API message 'af_packet_delete_reply'.
 type AfPacketDeleteReply struct {
        Retval int32
 }
 
-func (*AfPacketDeleteReply) GetMessageName() string {
-       return "af_packet_delete_reply"
-}
-func (*AfPacketDeleteReply) GetCrcString() string {
-       return "e8d4e804"
-}
-func (*AfPacketDeleteReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
+func (m *AfPacketDeleteReply) Reset()                        { *m = AfPacketDeleteReply{} }
+func (*AfPacketDeleteReply) GetMessageName() string          { return "af_packet_delete_reply" }
+func (*AfPacketDeleteReply) GetCrcString() string            { return "e8d4e804" }
+func (*AfPacketDeleteReply) GetMessageType() api.MessageType { return api.ReplyMessage }
 
-// AfPacketDetails represents VPP binary API message 'af_packet_details':
+// AfPacketDetails represents VPP binary API message 'af_packet_details'.
 type AfPacketDetails struct {
-       SwIfIndex  uint32
-       HostIfName []byte `struc:"[64]byte"`
+       SwIfIndex  InterfaceIndex
+       HostIfName string `struc:"[64]byte"`
 }
 
-func (*AfPacketDetails) GetMessageName() string {
-       return "af_packet_details"
-}
-func (*AfPacketDetails) GetCrcString() string {
-       return "057205fa"
-}
-func (*AfPacketDetails) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
+func (m *AfPacketDetails) Reset()                        { *m = AfPacketDetails{} }
+func (*AfPacketDetails) GetMessageName() string          { return "af_packet_details" }
+func (*AfPacketDetails) GetCrcString() string            { return "58c7c042" }
+func (*AfPacketDetails) GetMessageType() api.MessageType { return api.ReplyMessage }
 
-// AfPacketDump represents VPP binary API message 'af_packet_dump':
+// AfPacketDump represents VPP binary API message 'af_packet_dump'.
 type AfPacketDump struct{}
 
-func (*AfPacketDump) GetMessageName() string {
-       return "af_packet_dump"
-}
-func (*AfPacketDump) GetCrcString() string {
-       return "51077d14"
-}
-func (*AfPacketDump) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
+func (m *AfPacketDump) Reset()                        { *m = AfPacketDump{} }
+func (*AfPacketDump) GetMessageName() string          { return "af_packet_dump" }
+func (*AfPacketDump) GetCrcString() string            { return "51077d14" }
+func (*AfPacketDump) GetMessageType() api.MessageType { return api.RequestMessage }
 
-// AfPacketSetL4CksumOffload represents VPP binary API message 'af_packet_set_l4_cksum_offload':
+// AfPacketSetL4CksumOffload represents VPP binary API message 'af_packet_set_l4_cksum_offload'.
 type AfPacketSetL4CksumOffload struct {
-       SwIfIndex uint8
-       Set       uint8
+       SwIfIndex InterfaceIndex
+       Set       bool
 }
 
-func (*AfPacketSetL4CksumOffload) GetMessageName() string {
-       return "af_packet_set_l4_cksum_offload"
-}
-func (*AfPacketSetL4CksumOffload) GetCrcString() string {
-       return "86538585"
-}
-func (*AfPacketSetL4CksumOffload) GetMessageType() api.MessageType {
-       return api.RequestMessage
-}
+func (m *AfPacketSetL4CksumOffload) Reset()                        { *m = AfPacketSetL4CksumOffload{} }
+func (*AfPacketSetL4CksumOffload) GetMessageName() string          { return "af_packet_set_l4_cksum_offload" }
+func (*AfPacketSetL4CksumOffload) GetCrcString() string            { return "319cd5c8" }
+func (*AfPacketSetL4CksumOffload) GetMessageType() api.MessageType { return api.RequestMessage }
 
-// AfPacketSetL4CksumOffloadReply represents VPP binary API message 'af_packet_set_l4_cksum_offload_reply':
+// AfPacketSetL4CksumOffloadReply represents VPP binary API message 'af_packet_set_l4_cksum_offload_reply'.
 type AfPacketSetL4CksumOffloadReply struct {
        Retval int32
 }
 
+func (m *AfPacketSetL4CksumOffloadReply) Reset() { *m = AfPacketSetL4CksumOffloadReply{} }
 func (*AfPacketSetL4CksumOffloadReply) GetMessageName() string {
        return "af_packet_set_l4_cksum_offload_reply"
 }
-func (*AfPacketSetL4CksumOffloadReply) GetCrcString() string {
-       return "e8d4e804"
-}
-func (*AfPacketSetL4CksumOffloadReply) GetMessageType() api.MessageType {
-       return api.ReplyMessage
-}
+func (*AfPacketSetL4CksumOffloadReply) GetCrcString() string            { return "e8d4e804" }
+func (*AfPacketSetL4CksumOffloadReply) GetMessageType() api.MessageType { return api.ReplyMessage }
 
 func init() {
        api.RegisterMessage((*AfPacketCreate)(nil), "af_packet.AfPacketCreate")
@@ -188,40 +159,49 @@ func AllMessages() []api.Message {
        }
 }
 
-// Service represents VPP binary API services in af_packet module.
-type Service interface {
-       DumpAfPacket(ctx context.Context, in *AfPacketDump) ([]*AfPacketDetails, error)
+// RPCService represents RPC service API for af_packet module.
+type RPCService interface {
+       DumpAfPacket(ctx context.Context, in *AfPacketDump) (RPCService_DumpAfPacketClient, error)
        AfPacketCreate(ctx context.Context, in *AfPacketCreate) (*AfPacketCreateReply, error)
        AfPacketDelete(ctx context.Context, in *AfPacketDelete) (*AfPacketDeleteReply, error)
        AfPacketSetL4CksumOffload(ctx context.Context, in *AfPacketSetL4CksumOffload) (*AfPacketSetL4CksumOffloadReply, error)
 }
 
-type service struct {
+type serviceClient struct {
        ch api.Channel
 }
 
-func NewService(ch api.Channel) Service {
-       return &service{ch}
+func NewServiceClient(ch api.Channel) RPCService {
+       return &serviceClient{ch}
+}
+
+func (c *serviceClient) DumpAfPacket(ctx context.Context, in *AfPacketDump) (RPCService_DumpAfPacketClient, error) {
+       stream := c.ch.SendMultiRequest(in)
+       x := &serviceClient_DumpAfPacketClient{stream}
+       return x, nil
+}
+
+type RPCService_DumpAfPacketClient interface {
+       Recv() (*AfPacketDetails, error)
+}
+
+type serviceClient_DumpAfPacketClient struct {
+       api.MultiRequestCtx
 }
 
-func (c *service) DumpAfPacket(ctx context.Context, in *AfPacketDump) ([]*AfPacketDetails, error) {
-       var dump []*AfPacketDetails
-       req := c.ch.SendMultiRequest(in)
-       for {
-               m := new(AfPacketDetails)
-               stop, err := req.ReceiveReply(m)
-               if stop {
-                       break
-               }
-               if err != nil {
-                       return nil, err
-               }
-               dump = append(dump, m)
+func (c *serviceClient_DumpAfPacketClient) Recv() (*AfPacketDetails, error) {
+       m := new(AfPacketDetails)
+       stop, err := c.MultiRequestCtx.ReceiveReply(m)
+       if err != nil {
+               return nil, err
        }
-       return dump, nil
+       if stop {
+               return nil, io.EOF
+       }
+       return m, nil
 }
 
-func (c *service) AfPacketCreate(ctx context.Context, in *AfPacketCreate) (*AfPacketCreateReply, error) {
+func (c *serviceClient) AfPacketCreate(ctx context.Context, in *AfPacketCreate) (*AfPacketCreateReply, error) {
        out := new(AfPacketCreateReply)
        err := c.ch.SendRequest(in).ReceiveReply(out)
        if err != nil {
@@ -230,7 +210,7 @@ func (c *service) AfPacketCreate(ctx context.Context, in *AfPacketCreate) (*AfPa
        return out, nil
 }
 
-func (c *service) AfPacketDelete(ctx context.Context, in *AfPacketDelete) (*AfPacketDeleteReply, error) {
+func (c *serviceClient) AfPacketDelete(ctx context.Context, in *AfPacketDelete) (*AfPacketDeleteReply, error) {
        out := new(AfPacketDeleteReply)
        err := c.ch.SendRequest(in).ReceiveReply(out)
        if err != nil {
@@ -239,7 +219,7 @@ func (c *service) AfPacketDelete(ctx context.Context, in *AfPacketDelete) (*AfPa
        return out, nil
 }
 
-func (c *service) AfPacketSetL4CksumOffload(ctx context.Context, in *AfPacketSetL4CksumOffload) (*AfPacketSetL4CksumOffloadReply, error) {
+func (c *serviceClient) AfPacketSetL4CksumOffload(ctx context.Context, in *AfPacketSetL4CksumOffload) (*AfPacketSetL4CksumOffloadReply, error) {
        out := new(AfPacketSetL4CksumOffloadReply)
        err := c.ch.SendRequest(in).ReceiveReply(out)
        if err != nil {
@@ -247,3 +227,17 @@ func (c *service) AfPacketSetL4CksumOffload(ctx context.Context, in *AfPacketSet
        }
        return out, nil
 }
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the GoVPP api package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// GoVPP api package needs to be updated.
+const _ = api.GoVppAPIPackageIsVersion1 // please upgrade the GoVPP api package
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = api.RegisterMessage
+var _ = bytes.NewBuffer
+var _ = context.Background
+var _ = io.Copy
+var _ = strconv.Itoa
+var _ = struc.Pack