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 MessagesAvailableEffectsNotModified struct {
}
const MessagesAvailableEffectsNotModifiedTypeID = 0xd1ed9a5b
func (a MessagesAvailableEffectsNotModified ) construct () MessagesAvailableEffectsClass { return &a }
var (
_ bin .Encoder = &MessagesAvailableEffectsNotModified {}
_ bin .Decoder = &MessagesAvailableEffectsNotModified {}
_ bin .BareEncoder = &MessagesAvailableEffectsNotModified {}
_ bin .BareDecoder = &MessagesAvailableEffectsNotModified {}
_ MessagesAvailableEffectsClass = &MessagesAvailableEffectsNotModified {}
)
func (a *MessagesAvailableEffectsNotModified ) Zero () bool {
if a == nil {
return true
}
return true
}
func (a *MessagesAvailableEffectsNotModified ) String () string {
if a == nil {
return "MessagesAvailableEffectsNotModified(nil)"
}
type Alias MessagesAvailableEffectsNotModified
return fmt .Sprintf ("MessagesAvailableEffectsNotModified%+v" , Alias (*a ))
}
func (*MessagesAvailableEffectsNotModified ) TypeID () uint32 {
return MessagesAvailableEffectsNotModifiedTypeID
}
func (*MessagesAvailableEffectsNotModified ) TypeName () string {
return "messages.availableEffectsNotModified"
}
func (a *MessagesAvailableEffectsNotModified ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "messages.availableEffectsNotModified" ,
ID : MessagesAvailableEffectsNotModifiedTypeID ,
}
if a == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {}
return typ
}
func (a *MessagesAvailableEffectsNotModified ) Encode (b *bin .Buffer ) error {
if a == nil {
return fmt .Errorf ("can't encode messages.availableEffectsNotModified#d1ed9a5b as nil" )
}
b .PutID (MessagesAvailableEffectsNotModifiedTypeID )
return a .EncodeBare (b )
}
func (a *MessagesAvailableEffectsNotModified ) EncodeBare (b *bin .Buffer ) error {
if a == nil {
return fmt .Errorf ("can't encode messages.availableEffectsNotModified#d1ed9a5b as nil" )
}
return nil
}
func (a *MessagesAvailableEffectsNotModified ) Decode (b *bin .Buffer ) error {
if a == nil {
return fmt .Errorf ("can't decode messages.availableEffectsNotModified#d1ed9a5b to nil" )
}
if err := b .ConsumeID (MessagesAvailableEffectsNotModifiedTypeID ); err != nil {
return fmt .Errorf ("unable to decode messages.availableEffectsNotModified#d1ed9a5b: %w" , err )
}
return a .DecodeBare (b )
}
func (a *MessagesAvailableEffectsNotModified ) DecodeBare (b *bin .Buffer ) error {
if a == nil {
return fmt .Errorf ("can't decode messages.availableEffectsNotModified#d1ed9a5b to nil" )
}
return nil
}
type MessagesAvailableEffects struct {
Hash int
Effects []AvailableEffect
Documents []DocumentClass
}
const MessagesAvailableEffectsTypeID = 0xbddb616e
func (a MessagesAvailableEffects ) construct () MessagesAvailableEffectsClass { return &a }
var (
_ bin .Encoder = &MessagesAvailableEffects {}
_ bin .Decoder = &MessagesAvailableEffects {}
_ bin .BareEncoder = &MessagesAvailableEffects {}
_ bin .BareDecoder = &MessagesAvailableEffects {}
_ MessagesAvailableEffectsClass = &MessagesAvailableEffects {}
)
func (a *MessagesAvailableEffects ) Zero () bool {
if a == nil {
return true
}
if !(a .Hash == 0 ) {
return false
}
if !(a .Effects == nil ) {
return false
}
if !(a .Documents == nil ) {
return false
}
return true
}
func (a *MessagesAvailableEffects ) String () string {
if a == nil {
return "MessagesAvailableEffects(nil)"
}
type Alias MessagesAvailableEffects
return fmt .Sprintf ("MessagesAvailableEffects%+v" , Alias (*a ))
}
func (a *MessagesAvailableEffects ) FillFrom (from interface {
GetHash () (value int )
GetEffects () (value []AvailableEffect )
GetDocuments () (value []DocumentClass )
}) {
a .Hash = from .GetHash ()
a .Effects = from .GetEffects ()
a .Documents = from .GetDocuments ()
}
func (*MessagesAvailableEffects ) TypeID () uint32 {
return MessagesAvailableEffectsTypeID
}
func (*MessagesAvailableEffects ) TypeName () string {
return "messages.availableEffects"
}
func (a *MessagesAvailableEffects ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "messages.availableEffects" ,
ID : MessagesAvailableEffectsTypeID ,
}
if a == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Hash" ,
SchemaName : "hash" ,
},
{
Name : "Effects" ,
SchemaName : "effects" ,
},
{
Name : "Documents" ,
SchemaName : "documents" ,
},
}
return typ
}
func (a *MessagesAvailableEffects ) Encode (b *bin .Buffer ) error {
if a == nil {
return fmt .Errorf ("can't encode messages.availableEffects#bddb616e as nil" )
}
b .PutID (MessagesAvailableEffectsTypeID )
return a .EncodeBare (b )
}
func (a *MessagesAvailableEffects ) EncodeBare (b *bin .Buffer ) error {
if a == nil {
return fmt .Errorf ("can't encode messages.availableEffects#bddb616e as nil" )
}
b .PutInt (a .Hash )
b .PutVectorHeader (len (a .Effects ))
for idx , v := range a .Effects {
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode messages.availableEffects#bddb616e: field effects element with index %d: %w" , idx , err )
}
}
b .PutVectorHeader (len (a .Documents ))
for idx , v := range a .Documents {
if v == nil {
return fmt .Errorf ("unable to encode messages.availableEffects#bddb616e: field documents element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode messages.availableEffects#bddb616e: field documents element with index %d: %w" , idx , err )
}
}
return nil
}
func (a *MessagesAvailableEffects ) Decode (b *bin .Buffer ) error {
if a == nil {
return fmt .Errorf ("can't decode messages.availableEffects#bddb616e to nil" )
}
if err := b .ConsumeID (MessagesAvailableEffectsTypeID ); err != nil {
return fmt .Errorf ("unable to decode messages.availableEffects#bddb616e: %w" , err )
}
return a .DecodeBare (b )
}
func (a *MessagesAvailableEffects ) DecodeBare (b *bin .Buffer ) error {
if a == nil {
return fmt .Errorf ("can't decode messages.availableEffects#bddb616e to nil" )
}
{
value , err := b .Int ()
if err != nil {
return fmt .Errorf ("unable to decode messages.availableEffects#bddb616e: field hash: %w" , err )
}
a .Hash = value
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode messages.availableEffects#bddb616e: field effects: %w" , err )
}
if headerLen > 0 {
a .Effects = make ([]AvailableEffect , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
var value AvailableEffect
if err := value .Decode (b ); err != nil {
return fmt .Errorf ("unable to decode messages.availableEffects#bddb616e: field effects: %w" , err )
}
a .Effects = append (a .Effects , value )
}
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode messages.availableEffects#bddb616e: field documents: %w" , err )
}
if headerLen > 0 {
a .Documents = make ([]DocumentClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeDocument (b )
if err != nil {
return fmt .Errorf ("unable to decode messages.availableEffects#bddb616e: field documents: %w" , err )
}
a .Documents = append (a .Documents , value )
}
}
return nil
}
func (a *MessagesAvailableEffects ) GetHash () (value int ) {
if a == nil {
return
}
return a .Hash
}
func (a *MessagesAvailableEffects ) GetEffects () (value []AvailableEffect ) {
if a == nil {
return
}
return a .Effects
}
func (a *MessagesAvailableEffects ) GetDocuments () (value []DocumentClass ) {
if a == nil {
return
}
return a .Documents
}
func (a *MessagesAvailableEffects ) MapDocuments () (value DocumentClassArray ) {
return DocumentClassArray (a .Documents )
}
const MessagesAvailableEffectsClassName = "messages.AvailableEffects"
type MessagesAvailableEffectsClass interface {
bin .Encoder
bin .Decoder
bin .BareEncoder
bin .BareDecoder
construct () MessagesAvailableEffectsClass
TypeID () uint32
TypeName () string
String () string
Zero () bool
AsModified () (*MessagesAvailableEffects , bool )
}
func (a *MessagesAvailableEffectsNotModified ) AsModified () (*MessagesAvailableEffects , bool ) {
return nil , false
}
func (a *MessagesAvailableEffects ) AsModified () (*MessagesAvailableEffects , bool ) {
return a , true
}
func DecodeMessagesAvailableEffects (buf *bin .Buffer ) (MessagesAvailableEffectsClass , error ) {
id , err := buf .PeekID ()
if err != nil {
return nil , err
}
switch id {
case MessagesAvailableEffectsNotModifiedTypeID :
v := MessagesAvailableEffectsNotModified {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode MessagesAvailableEffectsClass: %w" , err )
}
return &v , nil
case MessagesAvailableEffectsTypeID :
v := MessagesAvailableEffects {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode MessagesAvailableEffectsClass: %w" , err )
}
return &v , nil
default :
return nil , fmt .Errorf ("unable to decode MessagesAvailableEffectsClass: %w" , bin .NewUnexpectedID (id ))
}
}
type MessagesAvailableEffectsBox struct {
AvailableEffects MessagesAvailableEffectsClass
}
func (b *MessagesAvailableEffectsBox ) Decode (buf *bin .Buffer ) error {
if b == nil {
return fmt .Errorf ("unable to decode MessagesAvailableEffectsBox to nil" )
}
v , err := DecodeMessagesAvailableEffects (buf )
if err != nil {
return fmt .Errorf ("unable to decode boxed value: %w" , err )
}
b .AvailableEffects = v
return nil
}
func (b *MessagesAvailableEffectsBox ) Encode (buf *bin .Buffer ) error {
if b == nil || b .AvailableEffects == nil {
return fmt .Errorf ("unable to encode MessagesAvailableEffectsClass as nil" )
}
return b .AvailableEffects .Encode (buf )
}
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 .