package tg
import (
"context"
"errors"
"fmt"
"sort"
"strings"
"go.uber.org/multierr"
"github.com/gotd/td/bin"
"github.com/gotd/td/tdjson"
"github.com/gotd/td/tdp"
"github.com/gotd/td/tgerr"
)
var (
_ = bin .Buffer {}
_ = context .Background ()
_ = fmt .Stringer (nil )
_ = strings .Builder {}
_ = errors .Is
_ = multierr .AppendInto
_ = sort .Ints
_ = tdp .Format
_ = tgerr .Error {}
_ = tdjson .Encoder {}
)
type MessageReactor struct {
Flags bin .Fields
Top bool
My bool
Anonymous bool
PeerID PeerClass
Count int
}
const MessageReactorTypeID = 0x4ba3a95a
var (
_ bin .Encoder = &MessageReactor {}
_ bin .Decoder = &MessageReactor {}
_ bin .BareEncoder = &MessageReactor {}
_ bin .BareDecoder = &MessageReactor {}
)
func (m *MessageReactor ) Zero () bool {
if m == nil {
return true
}
if !(m .Flags .Zero ()) {
return false
}
if !(m .Top == false ) {
return false
}
if !(m .My == false ) {
return false
}
if !(m .Anonymous == false ) {
return false
}
if !(m .PeerID == nil ) {
return false
}
if !(m .Count == 0 ) {
return false
}
return true
}
func (m *MessageReactor ) String () string {
if m == nil {
return "MessageReactor(nil)"
}
type Alias MessageReactor
return fmt .Sprintf ("MessageReactor%+v" , Alias (*m ))
}
func (m *MessageReactor ) FillFrom (from interface {
GetTop () (value bool )
GetMy () (value bool )
GetAnonymous () (value bool )
GetPeerID () (value PeerClass , ok bool )
GetCount () (value int )
}) {
m .Top = from .GetTop ()
m .My = from .GetMy ()
m .Anonymous = from .GetAnonymous ()
if val , ok := from .GetPeerID (); ok {
m .PeerID = val
}
m .Count = from .GetCount ()
}
func (*MessageReactor ) TypeID () uint32 {
return MessageReactorTypeID
}
func (*MessageReactor ) TypeName () string {
return "messageReactor"
}
func (m *MessageReactor ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "messageReactor" ,
ID : MessageReactorTypeID ,
}
if m == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Top" ,
SchemaName : "top" ,
Null : !m .Flags .Has (0 ),
},
{
Name : "My" ,
SchemaName : "my" ,
Null : !m .Flags .Has (1 ),
},
{
Name : "Anonymous" ,
SchemaName : "anonymous" ,
Null : !m .Flags .Has (2 ),
},
{
Name : "PeerID" ,
SchemaName : "peer_id" ,
Null : !m .Flags .Has (3 ),
},
{
Name : "Count" ,
SchemaName : "count" ,
},
}
return typ
}
func (m *MessageReactor ) SetFlags () {
if !(m .Top == false ) {
m .Flags .Set (0 )
}
if !(m .My == false ) {
m .Flags .Set (1 )
}
if !(m .Anonymous == false ) {
m .Flags .Set (2 )
}
if !(m .PeerID == nil ) {
m .Flags .Set (3 )
}
}
func (m *MessageReactor ) Encode (b *bin .Buffer ) error {
if m == nil {
return fmt .Errorf ("can't encode messageReactor#4ba3a95a as nil" )
}
b .PutID (MessageReactorTypeID )
return m .EncodeBare (b )
}
func (m *MessageReactor ) EncodeBare (b *bin .Buffer ) error {
if m == nil {
return fmt .Errorf ("can't encode messageReactor#4ba3a95a as nil" )
}
m .SetFlags ()
if err := m .Flags .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode messageReactor#4ba3a95a: field flags: %w" , err )
}
if m .Flags .Has (3 ) {
if m .PeerID == nil {
return fmt .Errorf ("unable to encode messageReactor#4ba3a95a: field peer_id is nil" )
}
if err := m .PeerID .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode messageReactor#4ba3a95a: field peer_id: %w" , err )
}
}
b .PutInt (m .Count )
return nil
}
func (m *MessageReactor ) Decode (b *bin .Buffer ) error {
if m == nil {
return fmt .Errorf ("can't decode messageReactor#4ba3a95a to nil" )
}
if err := b .ConsumeID (MessageReactorTypeID ); err != nil {
return fmt .Errorf ("unable to decode messageReactor#4ba3a95a: %w" , err )
}
return m .DecodeBare (b )
}
func (m *MessageReactor ) DecodeBare (b *bin .Buffer ) error {
if m == nil {
return fmt .Errorf ("can't decode messageReactor#4ba3a95a to nil" )
}
{
if err := m .Flags .Decode (b ); err != nil {
return fmt .Errorf ("unable to decode messageReactor#4ba3a95a: field flags: %w" , err )
}
}
m .Top = m .Flags .Has (0 )
m .My = m .Flags .Has (1 )
m .Anonymous = m .Flags .Has (2 )
if m .Flags .Has (3 ) {
value , err := DecodePeer (b )
if err != nil {
return fmt .Errorf ("unable to decode messageReactor#4ba3a95a: field peer_id: %w" , err )
}
m .PeerID = value
}
{
value , err := b .Int ()
if err != nil {
return fmt .Errorf ("unable to decode messageReactor#4ba3a95a: field count: %w" , err )
}
m .Count = value
}
return nil
}
func (m *MessageReactor ) SetTop (value bool ) {
if value {
m .Flags .Set (0 )
m .Top = true
} else {
m .Flags .Unset (0 )
m .Top = false
}
}
func (m *MessageReactor ) GetTop () (value bool ) {
if m == nil {
return
}
return m .Flags .Has (0 )
}
func (m *MessageReactor ) SetMy (value bool ) {
if value {
m .Flags .Set (1 )
m .My = true
} else {
m .Flags .Unset (1 )
m .My = false
}
}
func (m *MessageReactor ) GetMy () (value bool ) {
if m == nil {
return
}
return m .Flags .Has (1 )
}
func (m *MessageReactor ) SetAnonymous (value bool ) {
if value {
m .Flags .Set (2 )
m .Anonymous = true
} else {
m .Flags .Unset (2 )
m .Anonymous = false
}
}
func (m *MessageReactor ) GetAnonymous () (value bool ) {
if m == nil {
return
}
return m .Flags .Has (2 )
}
func (m *MessageReactor ) SetPeerID (value PeerClass ) {
m .Flags .Set (3 )
m .PeerID = value
}
func (m *MessageReactor ) GetPeerID () (value PeerClass , ok bool ) {
if m == nil {
return
}
if !m .Flags .Has (3 ) {
return value , false
}
return m .PeerID , true
}
func (m *MessageReactor ) GetCount () (value int ) {
if m == nil {
return
}
return m .Count
}
The pages are generated with Golds v0.8.4 . (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu .
PR and bug reports are welcome and can be submitted to the issue list .
Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds .