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 HelpUserInfoEmpty struct {
}
const HelpUserInfoEmptyTypeID = 0xf3ae2eed
func (u HelpUserInfoEmpty ) construct () HelpUserInfoClass { return &u }
var (
_ bin .Encoder = &HelpUserInfoEmpty {}
_ bin .Decoder = &HelpUserInfoEmpty {}
_ bin .BareEncoder = &HelpUserInfoEmpty {}
_ bin .BareDecoder = &HelpUserInfoEmpty {}
_ HelpUserInfoClass = &HelpUserInfoEmpty {}
)
func (u *HelpUserInfoEmpty ) Zero () bool {
if u == nil {
return true
}
return true
}
func (u *HelpUserInfoEmpty ) String () string {
if u == nil {
return "HelpUserInfoEmpty(nil)"
}
type Alias HelpUserInfoEmpty
return fmt .Sprintf ("HelpUserInfoEmpty%+v" , Alias (*u ))
}
func (*HelpUserInfoEmpty ) TypeID () uint32 {
return HelpUserInfoEmptyTypeID
}
func (*HelpUserInfoEmpty ) TypeName () string {
return "help.userInfoEmpty"
}
func (u *HelpUserInfoEmpty ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "help.userInfoEmpty" ,
ID : HelpUserInfoEmptyTypeID ,
}
if u == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {}
return typ
}
func (u *HelpUserInfoEmpty ) Encode (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't encode help.userInfoEmpty#f3ae2eed as nil" )
}
b .PutID (HelpUserInfoEmptyTypeID )
return u .EncodeBare (b )
}
func (u *HelpUserInfoEmpty ) EncodeBare (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't encode help.userInfoEmpty#f3ae2eed as nil" )
}
return nil
}
func (u *HelpUserInfoEmpty ) Decode (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't decode help.userInfoEmpty#f3ae2eed to nil" )
}
if err := b .ConsumeID (HelpUserInfoEmptyTypeID ); err != nil {
return fmt .Errorf ("unable to decode help.userInfoEmpty#f3ae2eed: %w" , err )
}
return u .DecodeBare (b )
}
func (u *HelpUserInfoEmpty ) DecodeBare (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't decode help.userInfoEmpty#f3ae2eed to nil" )
}
return nil
}
type HelpUserInfo struct {
Message string
Entities []MessageEntityClass
Author string
Date int
}
const HelpUserInfoTypeID = 0x1eb3758
func (u HelpUserInfo ) construct () HelpUserInfoClass { return &u }
var (
_ bin .Encoder = &HelpUserInfo {}
_ bin .Decoder = &HelpUserInfo {}
_ bin .BareEncoder = &HelpUserInfo {}
_ bin .BareDecoder = &HelpUserInfo {}
_ HelpUserInfoClass = &HelpUserInfo {}
)
func (u *HelpUserInfo ) Zero () bool {
if u == nil {
return true
}
if !(u .Message == "" ) {
return false
}
if !(u .Entities == nil ) {
return false
}
if !(u .Author == "" ) {
return false
}
if !(u .Date == 0 ) {
return false
}
return true
}
func (u *HelpUserInfo ) String () string {
if u == nil {
return "HelpUserInfo(nil)"
}
type Alias HelpUserInfo
return fmt .Sprintf ("HelpUserInfo%+v" , Alias (*u ))
}
func (u *HelpUserInfo ) FillFrom (from interface {
GetMessage () (value string )
GetEntities () (value []MessageEntityClass )
GetAuthor () (value string )
GetDate () (value int )
}) {
u .Message = from .GetMessage ()
u .Entities = from .GetEntities ()
u .Author = from .GetAuthor ()
u .Date = from .GetDate ()
}
func (*HelpUserInfo ) TypeID () uint32 {
return HelpUserInfoTypeID
}
func (*HelpUserInfo ) TypeName () string {
return "help.userInfo"
}
func (u *HelpUserInfo ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "help.userInfo" ,
ID : HelpUserInfoTypeID ,
}
if u == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Message" ,
SchemaName : "message" ,
},
{
Name : "Entities" ,
SchemaName : "entities" ,
},
{
Name : "Author" ,
SchemaName : "author" ,
},
{
Name : "Date" ,
SchemaName : "date" ,
},
}
return typ
}
func (u *HelpUserInfo ) Encode (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't encode help.userInfo#1eb3758 as nil" )
}
b .PutID (HelpUserInfoTypeID )
return u .EncodeBare (b )
}
func (u *HelpUserInfo ) EncodeBare (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't encode help.userInfo#1eb3758 as nil" )
}
b .PutString (u .Message )
b .PutVectorHeader (len (u .Entities ))
for idx , v := range u .Entities {
if v == nil {
return fmt .Errorf ("unable to encode help.userInfo#1eb3758: field entities element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode help.userInfo#1eb3758: field entities element with index %d: %w" , idx , err )
}
}
b .PutString (u .Author )
b .PutInt (u .Date )
return nil
}
func (u *HelpUserInfo ) Decode (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't decode help.userInfo#1eb3758 to nil" )
}
if err := b .ConsumeID (HelpUserInfoTypeID ); err != nil {
return fmt .Errorf ("unable to decode help.userInfo#1eb3758: %w" , err )
}
return u .DecodeBare (b )
}
func (u *HelpUserInfo ) DecodeBare (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't decode help.userInfo#1eb3758 to nil" )
}
{
value , err := b .String ()
if err != nil {
return fmt .Errorf ("unable to decode help.userInfo#1eb3758: field message: %w" , err )
}
u .Message = value
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode help.userInfo#1eb3758: field entities: %w" , err )
}
if headerLen > 0 {
u .Entities = make ([]MessageEntityClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeMessageEntity (b )
if err != nil {
return fmt .Errorf ("unable to decode help.userInfo#1eb3758: field entities: %w" , err )
}
u .Entities = append (u .Entities , value )
}
}
{
value , err := b .String ()
if err != nil {
return fmt .Errorf ("unable to decode help.userInfo#1eb3758: field author: %w" , err )
}
u .Author = value
}
{
value , err := b .Int ()
if err != nil {
return fmt .Errorf ("unable to decode help.userInfo#1eb3758: field date: %w" , err )
}
u .Date = value
}
return nil
}
func (u *HelpUserInfo ) GetMessage () (value string ) {
if u == nil {
return
}
return u .Message
}
func (u *HelpUserInfo ) GetEntities () (value []MessageEntityClass ) {
if u == nil {
return
}
return u .Entities
}
func (u *HelpUserInfo ) GetAuthor () (value string ) {
if u == nil {
return
}
return u .Author
}
func (u *HelpUserInfo ) GetDate () (value int ) {
if u == nil {
return
}
return u .Date
}
func (u *HelpUserInfo ) MapEntities () (value MessageEntityClassArray ) {
return MessageEntityClassArray (u .Entities )
}
const HelpUserInfoClassName = "help.UserInfo"
type HelpUserInfoClass interface {
bin .Encoder
bin .Decoder
bin .BareEncoder
bin .BareDecoder
construct () HelpUserInfoClass
TypeID () uint32
TypeName () string
String () string
Zero () bool
AsNotEmpty () (*HelpUserInfo , bool )
}
func (u *HelpUserInfoEmpty ) AsNotEmpty () (*HelpUserInfo , bool ) {
return nil , false
}
func (u *HelpUserInfo ) AsNotEmpty () (*HelpUserInfo , bool ) {
return u , true
}
func DecodeHelpUserInfo (buf *bin .Buffer ) (HelpUserInfoClass , error ) {
id , err := buf .PeekID ()
if err != nil {
return nil , err
}
switch id {
case HelpUserInfoEmptyTypeID :
v := HelpUserInfoEmpty {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode HelpUserInfoClass: %w" , err )
}
return &v , nil
case HelpUserInfoTypeID :
v := HelpUserInfo {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode HelpUserInfoClass: %w" , err )
}
return &v , nil
default :
return nil , fmt .Errorf ("unable to decode HelpUserInfoClass: %w" , bin .NewUnexpectedID (id ))
}
}
type HelpUserInfoBox struct {
UserInfo HelpUserInfoClass
}
func (b *HelpUserInfoBox ) Decode (buf *bin .Buffer ) error {
if b == nil {
return fmt .Errorf ("unable to decode HelpUserInfoBox to nil" )
}
v , err := DecodeHelpUserInfo (buf )
if err != nil {
return fmt .Errorf ("unable to decode boxed value: %w" , err )
}
b .UserInfo = v
return nil
}
func (b *HelpUserInfoBox ) Encode (buf *bin .Buffer ) error {
if b == nil || b .UserInfo == nil {
return fmt .Errorf ("unable to encode HelpUserInfoClass as nil" )
}
return b .UserInfo .Encode (buf )
}
The pages are generated with Golds v0.6.7 . (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 @Go100and1 (reachable from the left QR code) to get the latest news of Golds .