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 AicomposeTonesNotModified struct {
}
const AicomposeTonesNotModifiedTypeID = 0xc1f46103
func (t AicomposeTonesNotModified ) construct () AicomposeTonesClass { return &t }
var (
_ bin .Encoder = &AicomposeTonesNotModified {}
_ bin .Decoder = &AicomposeTonesNotModified {}
_ bin .BareEncoder = &AicomposeTonesNotModified {}
_ bin .BareDecoder = &AicomposeTonesNotModified {}
_ AicomposeTonesClass = &AicomposeTonesNotModified {}
)
func (t *AicomposeTonesNotModified ) Zero () bool {
if t == nil {
return true
}
return true
}
func (t *AicomposeTonesNotModified ) String () string {
if t == nil {
return "AicomposeTonesNotModified(nil)"
}
type Alias AicomposeTonesNotModified
return fmt .Sprintf ("AicomposeTonesNotModified%+v" , Alias (*t ))
}
func (*AicomposeTonesNotModified ) TypeID () uint32 {
return AicomposeTonesNotModifiedTypeID
}
func (*AicomposeTonesNotModified ) TypeName () string {
return "aicompose.tonesNotModified"
}
func (t *AicomposeTonesNotModified ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "aicompose.tonesNotModified" ,
ID : AicomposeTonesNotModifiedTypeID ,
}
if t == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {}
return typ
}
func (t *AicomposeTonesNotModified ) Encode (b *bin .Buffer ) error {
if t == nil {
return fmt .Errorf ("can't encode aicompose.tonesNotModified#c1f46103 as nil" )
}
b .PutID (AicomposeTonesNotModifiedTypeID )
return t .EncodeBare (b )
}
func (t *AicomposeTonesNotModified ) EncodeBare (b *bin .Buffer ) error {
if t == nil {
return fmt .Errorf ("can't encode aicompose.tonesNotModified#c1f46103 as nil" )
}
return nil
}
func (t *AicomposeTonesNotModified ) Decode (b *bin .Buffer ) error {
if t == nil {
return fmt .Errorf ("can't decode aicompose.tonesNotModified#c1f46103 to nil" )
}
if err := b .ConsumeID (AicomposeTonesNotModifiedTypeID ); err != nil {
return fmt .Errorf ("unable to decode aicompose.tonesNotModified#c1f46103: %w" , err )
}
return t .DecodeBare (b )
}
func (t *AicomposeTonesNotModified ) DecodeBare (b *bin .Buffer ) error {
if t == nil {
return fmt .Errorf ("can't decode aicompose.tonesNotModified#c1f46103 to nil" )
}
return nil
}
type AicomposeTones struct {
Hash int64
Tones []AiComposeToneClass
Users []UserClass
}
const AicomposeTonesTypeID = 0x6c9d0efe
func (t AicomposeTones ) construct () AicomposeTonesClass { return &t }
var (
_ bin .Encoder = &AicomposeTones {}
_ bin .Decoder = &AicomposeTones {}
_ bin .BareEncoder = &AicomposeTones {}
_ bin .BareDecoder = &AicomposeTones {}
_ AicomposeTonesClass = &AicomposeTones {}
)
func (t *AicomposeTones ) Zero () bool {
if t == nil {
return true
}
if !(t .Hash == 0 ) {
return false
}
if !(t .Tones == nil ) {
return false
}
if !(t .Users == nil ) {
return false
}
return true
}
func (t *AicomposeTones ) String () string {
if t == nil {
return "AicomposeTones(nil)"
}
type Alias AicomposeTones
return fmt .Sprintf ("AicomposeTones%+v" , Alias (*t ))
}
func (t *AicomposeTones ) FillFrom (from interface {
GetHash () (value int64 )
GetTones () (value []AiComposeToneClass )
GetUsers () (value []UserClass )
}) {
t .Hash = from .GetHash ()
t .Tones = from .GetTones ()
t .Users = from .GetUsers ()
}
func (*AicomposeTones ) TypeID () uint32 {
return AicomposeTonesTypeID
}
func (*AicomposeTones ) TypeName () string {
return "aicompose.tones"
}
func (t *AicomposeTones ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "aicompose.tones" ,
ID : AicomposeTonesTypeID ,
}
if t == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Hash" ,
SchemaName : "hash" ,
},
{
Name : "Tones" ,
SchemaName : "tones" ,
},
{
Name : "Users" ,
SchemaName : "users" ,
},
}
return typ
}
func (t *AicomposeTones ) Encode (b *bin .Buffer ) error {
if t == nil {
return fmt .Errorf ("can't encode aicompose.tones#6c9d0efe as nil" )
}
b .PutID (AicomposeTonesTypeID )
return t .EncodeBare (b )
}
func (t *AicomposeTones ) EncodeBare (b *bin .Buffer ) error {
if t == nil {
return fmt .Errorf ("can't encode aicompose.tones#6c9d0efe as nil" )
}
b .PutLong (t .Hash )
b .PutVectorHeader (len (t .Tones ))
for idx , v := range t .Tones {
if v == nil {
return fmt .Errorf ("unable to encode aicompose.tones#6c9d0efe: field tones element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode aicompose.tones#6c9d0efe: field tones element with index %d: %w" , idx , err )
}
}
b .PutVectorHeader (len (t .Users ))
for idx , v := range t .Users {
if v == nil {
return fmt .Errorf ("unable to encode aicompose.tones#6c9d0efe: field users element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode aicompose.tones#6c9d0efe: field users element with index %d: %w" , idx , err )
}
}
return nil
}
func (t *AicomposeTones ) Decode (b *bin .Buffer ) error {
if t == nil {
return fmt .Errorf ("can't decode aicompose.tones#6c9d0efe to nil" )
}
if err := b .ConsumeID (AicomposeTonesTypeID ); err != nil {
return fmt .Errorf ("unable to decode aicompose.tones#6c9d0efe: %w" , err )
}
return t .DecodeBare (b )
}
func (t *AicomposeTones ) DecodeBare (b *bin .Buffer ) error {
if t == nil {
return fmt .Errorf ("can't decode aicompose.tones#6c9d0efe to nil" )
}
{
value , err := b .Long ()
if err != nil {
return fmt .Errorf ("unable to decode aicompose.tones#6c9d0efe: field hash: %w" , err )
}
t .Hash = value
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode aicompose.tones#6c9d0efe: field tones: %w" , err )
}
if headerLen > 0 {
t .Tones = make ([]AiComposeToneClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeAiComposeTone (b )
if err != nil {
return fmt .Errorf ("unable to decode aicompose.tones#6c9d0efe: field tones: %w" , err )
}
t .Tones = append (t .Tones , value )
}
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode aicompose.tones#6c9d0efe: field users: %w" , err )
}
if headerLen > 0 {
t .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 aicompose.tones#6c9d0efe: field users: %w" , err )
}
t .Users = append (t .Users , value )
}
}
return nil
}
func (t *AicomposeTones ) GetHash () (value int64 ) {
if t == nil {
return
}
return t .Hash
}
func (t *AicomposeTones ) GetTones () (value []AiComposeToneClass ) {
if t == nil {
return
}
return t .Tones
}
func (t *AicomposeTones ) GetUsers () (value []UserClass ) {
if t == nil {
return
}
return t .Users
}
func (t *AicomposeTones ) MapTones () (value AiComposeToneClassArray ) {
return AiComposeToneClassArray (t .Tones )
}
func (t *AicomposeTones ) MapUsers () (value UserClassArray ) {
return UserClassArray (t .Users )
}
const AicomposeTonesClassName = "aicompose.Tones"
type AicomposeTonesClass interface {
bin .Encoder
bin .Decoder
bin .BareEncoder
bin .BareDecoder
construct () AicomposeTonesClass
TypeID () uint32
TypeName () string
String () string
Zero () bool
AsModified () (*AicomposeTones , bool )
}
func (t *AicomposeTonesNotModified ) AsModified () (*AicomposeTones , bool ) {
return nil , false
}
func (t *AicomposeTones ) AsModified () (*AicomposeTones , bool ) {
return t , true
}
func DecodeAicomposeTones (buf *bin .Buffer ) (AicomposeTonesClass , error ) {
id , err := buf .PeekID ()
if err != nil {
return nil , err
}
switch id {
case AicomposeTonesNotModifiedTypeID :
v := AicomposeTonesNotModified {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode AicomposeTonesClass: %w" , err )
}
return &v , nil
case AicomposeTonesTypeID :
v := AicomposeTones {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode AicomposeTonesClass: %w" , err )
}
return &v , nil
default :
return nil , fmt .Errorf ("unable to decode AicomposeTonesClass: %w" , bin .NewUnexpectedID (id ))
}
}
type AicomposeTonesBox struct {
Tones AicomposeTonesClass
}
func (b *AicomposeTonesBox ) Decode (buf *bin .Buffer ) error {
if b == nil {
return fmt .Errorf ("unable to decode AicomposeTonesBox to nil" )
}
v , err := DecodeAicomposeTones (buf )
if err != nil {
return fmt .Errorf ("unable to decode boxed value: %w" , err )
}
b .Tones = v
return nil
}
func (b *AicomposeTonesBox ) Encode (buf *bin .Buffer ) error {
if b == nil || b .Tones == nil {
return fmt .Errorf ("unable to encode AicomposeTonesClass as nil" )
}
return b .Tones .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 .