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 DialogPeer struct {
Peer PeerClass
}
const DialogPeerTypeID = 0xe56dbf05
func (d DialogPeer ) construct () DialogPeerClass { return &d }
var (
_ bin .Encoder = &DialogPeer {}
_ bin .Decoder = &DialogPeer {}
_ bin .BareEncoder = &DialogPeer {}
_ bin .BareDecoder = &DialogPeer {}
_ DialogPeerClass = &DialogPeer {}
)
func (d *DialogPeer ) Zero () bool {
if d == nil {
return true
}
if !(d .Peer == nil ) {
return false
}
return true
}
func (d *DialogPeer ) String () string {
if d == nil {
return "DialogPeer(nil)"
}
type Alias DialogPeer
return fmt .Sprintf ("DialogPeer%+v" , Alias (*d ))
}
func (d *DialogPeer ) FillFrom (from interface {
GetPeer () (value PeerClass )
}) {
d .Peer = from .GetPeer ()
}
func (*DialogPeer ) TypeID () uint32 {
return DialogPeerTypeID
}
func (*DialogPeer ) TypeName () string {
return "dialogPeer"
}
func (d *DialogPeer ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "dialogPeer" ,
ID : DialogPeerTypeID ,
}
if d == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Peer" ,
SchemaName : "peer" ,
},
}
return typ
}
func (d *DialogPeer ) Encode (b *bin .Buffer ) error {
if d == nil {
return fmt .Errorf ("can't encode dialogPeer#e56dbf05 as nil" )
}
b .PutID (DialogPeerTypeID )
return d .EncodeBare (b )
}
func (d *DialogPeer ) EncodeBare (b *bin .Buffer ) error {
if d == nil {
return fmt .Errorf ("can't encode dialogPeer#e56dbf05 as nil" )
}
if d .Peer == nil {
return fmt .Errorf ("unable to encode dialogPeer#e56dbf05: field peer is nil" )
}
if err := d .Peer .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode dialogPeer#e56dbf05: field peer: %w" , err )
}
return nil
}
func (d *DialogPeer ) Decode (b *bin .Buffer ) error {
if d == nil {
return fmt .Errorf ("can't decode dialogPeer#e56dbf05 to nil" )
}
if err := b .ConsumeID (DialogPeerTypeID ); err != nil {
return fmt .Errorf ("unable to decode dialogPeer#e56dbf05: %w" , err )
}
return d .DecodeBare (b )
}
func (d *DialogPeer ) DecodeBare (b *bin .Buffer ) error {
if d == nil {
return fmt .Errorf ("can't decode dialogPeer#e56dbf05 to nil" )
}
{
value , err := DecodePeer (b )
if err != nil {
return fmt .Errorf ("unable to decode dialogPeer#e56dbf05: field peer: %w" , err )
}
d .Peer = value
}
return nil
}
func (d *DialogPeer ) GetPeer () (value PeerClass ) {
if d == nil {
return
}
return d .Peer
}
type DialogPeerFolder struct {
FolderID int
}
const DialogPeerFolderTypeID = 0x514519e2
func (d DialogPeerFolder ) construct () DialogPeerClass { return &d }
var (
_ bin .Encoder = &DialogPeerFolder {}
_ bin .Decoder = &DialogPeerFolder {}
_ bin .BareEncoder = &DialogPeerFolder {}
_ bin .BareDecoder = &DialogPeerFolder {}
_ DialogPeerClass = &DialogPeerFolder {}
)
func (d *DialogPeerFolder ) Zero () bool {
if d == nil {
return true
}
if !(d .FolderID == 0 ) {
return false
}
return true
}
func (d *DialogPeerFolder ) String () string {
if d == nil {
return "DialogPeerFolder(nil)"
}
type Alias DialogPeerFolder
return fmt .Sprintf ("DialogPeerFolder%+v" , Alias (*d ))
}
func (d *DialogPeerFolder ) FillFrom (from interface {
GetFolderID () (value int )
}) {
d .FolderID = from .GetFolderID ()
}
func (*DialogPeerFolder ) TypeID () uint32 {
return DialogPeerFolderTypeID
}
func (*DialogPeerFolder ) TypeName () string {
return "dialogPeerFolder"
}
func (d *DialogPeerFolder ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "dialogPeerFolder" ,
ID : DialogPeerFolderTypeID ,
}
if d == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "FolderID" ,
SchemaName : "folder_id" ,
},
}
return typ
}
func (d *DialogPeerFolder ) Encode (b *bin .Buffer ) error {
if d == nil {
return fmt .Errorf ("can't encode dialogPeerFolder#514519e2 as nil" )
}
b .PutID (DialogPeerFolderTypeID )
return d .EncodeBare (b )
}
func (d *DialogPeerFolder ) EncodeBare (b *bin .Buffer ) error {
if d == nil {
return fmt .Errorf ("can't encode dialogPeerFolder#514519e2 as nil" )
}
b .PutInt (d .FolderID )
return nil
}
func (d *DialogPeerFolder ) Decode (b *bin .Buffer ) error {
if d == nil {
return fmt .Errorf ("can't decode dialogPeerFolder#514519e2 to nil" )
}
if err := b .ConsumeID (DialogPeerFolderTypeID ); err != nil {
return fmt .Errorf ("unable to decode dialogPeerFolder#514519e2: %w" , err )
}
return d .DecodeBare (b )
}
func (d *DialogPeerFolder ) DecodeBare (b *bin .Buffer ) error {
if d == nil {
return fmt .Errorf ("can't decode dialogPeerFolder#514519e2 to nil" )
}
{
value , err := b .Int ()
if err != nil {
return fmt .Errorf ("unable to decode dialogPeerFolder#514519e2: field folder_id: %w" , err )
}
d .FolderID = value
}
return nil
}
func (d *DialogPeerFolder ) GetFolderID () (value int ) {
if d == nil {
return
}
return d .FolderID
}
const DialogPeerClassName = "DialogPeer"
type DialogPeerClass interface {
bin .Encoder
bin .Decoder
bin .BareEncoder
bin .BareDecoder
construct () DialogPeerClass
TypeID () uint32
TypeName () string
String () string
Zero () bool
}
func (d *DialogPeerFolder ) AsInput () *InputDialogPeerFolder {
value := new (InputDialogPeerFolder )
value .FolderID = d .GetFolderID ()
return value
}
func DecodeDialogPeer (buf *bin .Buffer ) (DialogPeerClass , error ) {
id , err := buf .PeekID ()
if err != nil {
return nil , err
}
switch id {
case DialogPeerTypeID :
v := DialogPeer {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode DialogPeerClass: %w" , err )
}
return &v , nil
case DialogPeerFolderTypeID :
v := DialogPeerFolder {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode DialogPeerClass: %w" , err )
}
return &v , nil
default :
return nil , fmt .Errorf ("unable to decode DialogPeerClass: %w" , bin .NewUnexpectedID (id ))
}
}
type DialogPeerBox struct {
DialogPeer DialogPeerClass
}
func (b *DialogPeerBox ) Decode (buf *bin .Buffer ) error {
if b == nil {
return fmt .Errorf ("unable to decode DialogPeerBox to nil" )
}
v , err := DecodeDialogPeer (buf )
if err != nil {
return fmt .Errorf ("unable to decode boxed value: %w" , err )
}
b .DialogPeer = v
return nil
}
func (b *DialogPeerBox ) Encode (buf *bin .Buffer ) error {
if b == nil || b .DialogPeer == nil {
return fmt .Errorf ("unable to encode DialogPeerClass as nil" )
}
return b .DialogPeer .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 .