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 UsersUsers struct {
Users []UserClass
}
const UsersUsersTypeID = 0x62d706b8
func (u UsersUsers ) construct () UsersUsersClass { return &u }
var (
_ bin .Encoder = &UsersUsers {}
_ bin .Decoder = &UsersUsers {}
_ bin .BareEncoder = &UsersUsers {}
_ bin .BareDecoder = &UsersUsers {}
_ UsersUsersClass = &UsersUsers {}
)
func (u *UsersUsers ) Zero () bool {
if u == nil {
return true
}
if !(u .Users == nil ) {
return false
}
return true
}
func (u *UsersUsers ) String () string {
if u == nil {
return "UsersUsers(nil)"
}
type Alias UsersUsers
return fmt .Sprintf ("UsersUsers%+v" , Alias (*u ))
}
func (u *UsersUsers ) FillFrom (from interface {
GetUsers () (value []UserClass )
}) {
u .Users = from .GetUsers ()
}
func (*UsersUsers ) TypeID () uint32 {
return UsersUsersTypeID
}
func (*UsersUsers ) TypeName () string {
return "users.users"
}
func (u *UsersUsers ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "users.users" ,
ID : UsersUsersTypeID ,
}
if u == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Users" ,
SchemaName : "users" ,
},
}
return typ
}
func (u *UsersUsers ) Encode (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't encode users.users#62d706b8 as nil" )
}
b .PutID (UsersUsersTypeID )
return u .EncodeBare (b )
}
func (u *UsersUsers ) EncodeBare (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't encode users.users#62d706b8 as nil" )
}
b .PutVectorHeader (len (u .Users ))
for idx , v := range u .Users {
if v == nil {
return fmt .Errorf ("unable to encode users.users#62d706b8: field users element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode users.users#62d706b8: field users element with index %d: %w" , idx , err )
}
}
return nil
}
func (u *UsersUsers ) Decode (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't decode users.users#62d706b8 to nil" )
}
if err := b .ConsumeID (UsersUsersTypeID ); err != nil {
return fmt .Errorf ("unable to decode users.users#62d706b8: %w" , err )
}
return u .DecodeBare (b )
}
func (u *UsersUsers ) DecodeBare (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't decode users.users#62d706b8 to nil" )
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode users.users#62d706b8: field users: %w" , err )
}
if headerLen > 0 {
u .Users = make ([]UserClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeUser (b )
if err != nil {
return fmt .Errorf ("unable to decode users.users#62d706b8: field users: %w" , err )
}
u .Users = append (u .Users , value )
}
}
return nil
}
func (u *UsersUsers ) GetUsers () (value []UserClass ) {
if u == nil {
return
}
return u .Users
}
func (u *UsersUsers ) MapUsers () (value UserClassArray ) {
return UserClassArray (u .Users )
}
type UsersUsersSlice struct {
Count int
Users []UserClass
}
const UsersUsersSliceTypeID = 0x315a4974
func (u UsersUsersSlice ) construct () UsersUsersClass { return &u }
var (
_ bin .Encoder = &UsersUsersSlice {}
_ bin .Decoder = &UsersUsersSlice {}
_ bin .BareEncoder = &UsersUsersSlice {}
_ bin .BareDecoder = &UsersUsersSlice {}
_ UsersUsersClass = &UsersUsersSlice {}
)
func (u *UsersUsersSlice ) Zero () bool {
if u == nil {
return true
}
if !(u .Count == 0 ) {
return false
}
if !(u .Users == nil ) {
return false
}
return true
}
func (u *UsersUsersSlice ) String () string {
if u == nil {
return "UsersUsersSlice(nil)"
}
type Alias UsersUsersSlice
return fmt .Sprintf ("UsersUsersSlice%+v" , Alias (*u ))
}
func (u *UsersUsersSlice ) FillFrom (from interface {
GetCount () (value int )
GetUsers () (value []UserClass )
}) {
u .Count = from .GetCount ()
u .Users = from .GetUsers ()
}
func (*UsersUsersSlice ) TypeID () uint32 {
return UsersUsersSliceTypeID
}
func (*UsersUsersSlice ) TypeName () string {
return "users.usersSlice"
}
func (u *UsersUsersSlice ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "users.usersSlice" ,
ID : UsersUsersSliceTypeID ,
}
if u == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Count" ,
SchemaName : "count" ,
},
{
Name : "Users" ,
SchemaName : "users" ,
},
}
return typ
}
func (u *UsersUsersSlice ) Encode (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't encode users.usersSlice#315a4974 as nil" )
}
b .PutID (UsersUsersSliceTypeID )
return u .EncodeBare (b )
}
func (u *UsersUsersSlice ) EncodeBare (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't encode users.usersSlice#315a4974 as nil" )
}
b .PutInt (u .Count )
b .PutVectorHeader (len (u .Users ))
for idx , v := range u .Users {
if v == nil {
return fmt .Errorf ("unable to encode users.usersSlice#315a4974: field users element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode users.usersSlice#315a4974: field users element with index %d: %w" , idx , err )
}
}
return nil
}
func (u *UsersUsersSlice ) Decode (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't decode users.usersSlice#315a4974 to nil" )
}
if err := b .ConsumeID (UsersUsersSliceTypeID ); err != nil {
return fmt .Errorf ("unable to decode users.usersSlice#315a4974: %w" , err )
}
return u .DecodeBare (b )
}
func (u *UsersUsersSlice ) DecodeBare (b *bin .Buffer ) error {
if u == nil {
return fmt .Errorf ("can't decode users.usersSlice#315a4974 to nil" )
}
{
value , err := b .Int ()
if err != nil {
return fmt .Errorf ("unable to decode users.usersSlice#315a4974: field count: %w" , err )
}
u .Count = value
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode users.usersSlice#315a4974: field users: %w" , err )
}
if headerLen > 0 {
u .Users = make ([]UserClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeUser (b )
if err != nil {
return fmt .Errorf ("unable to decode users.usersSlice#315a4974: field users: %w" , err )
}
u .Users = append (u .Users , value )
}
}
return nil
}
func (u *UsersUsersSlice ) GetCount () (value int ) {
if u == nil {
return
}
return u .Count
}
func (u *UsersUsersSlice ) GetUsers () (value []UserClass ) {
if u == nil {
return
}
return u .Users
}
func (u *UsersUsersSlice ) MapUsers () (value UserClassArray ) {
return UserClassArray (u .Users )
}
const UsersUsersClassName = "users.Users"
type UsersUsersClass interface {
bin .Encoder
bin .Decoder
bin .BareEncoder
bin .BareDecoder
construct () UsersUsersClass
TypeID () uint32
TypeName () string
String () string
Zero () bool
GetUsers () (value []UserClass )
MapUsers () (value UserClassArray )
}
func DecodeUsersUsers (buf *bin .Buffer ) (UsersUsersClass , error ) {
id , err := buf .PeekID ()
if err != nil {
return nil , err
}
switch id {
case UsersUsersTypeID :
v := UsersUsers {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode UsersUsersClass: %w" , err )
}
return &v , nil
case UsersUsersSliceTypeID :
v := UsersUsersSlice {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode UsersUsersClass: %w" , err )
}
return &v , nil
default :
return nil , fmt .Errorf ("unable to decode UsersUsersClass: %w" , bin .NewUnexpectedID (id ))
}
}
type UsersUsersBox struct {
Users UsersUsersClass
}
func (b *UsersUsersBox ) Decode (buf *bin .Buffer ) error {
if b == nil {
return fmt .Errorf ("unable to decode UsersUsersBox to nil" )
}
v , err := DecodeUsersUsers (buf )
if err != nil {
return fmt .Errorf ("unable to decode boxed value: %w" , err )
}
b .Users = v
return nil
}
func (b *UsersUsersBox ) Encode (buf *bin .Buffer ) error {
if b == nil || b .Users == nil {
return fmt .Errorf ("unable to encode UsersUsersClass as nil" )
}
return b .Users .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 .