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 RichMessage struct {
Flags bin .Fields
Rtl bool
Part bool
Blocks []PageBlockClass
Photos []PhotoClass
Documents []DocumentClass
}
const RichMessageTypeID = 0xbaf39d8b
var (
_ bin .Encoder = &RichMessage {}
_ bin .Decoder = &RichMessage {}
_ bin .BareEncoder = &RichMessage {}
_ bin .BareDecoder = &RichMessage {}
)
func (r *RichMessage ) Zero () bool {
if r == nil {
return true
}
if !(r .Flags .Zero ()) {
return false
}
if !(r .Rtl == false ) {
return false
}
if !(r .Part == false ) {
return false
}
if !(r .Blocks == nil ) {
return false
}
if !(r .Photos == nil ) {
return false
}
if !(r .Documents == nil ) {
return false
}
return true
}
func (r *RichMessage ) String () string {
if r == nil {
return "RichMessage(nil)"
}
type Alias RichMessage
return fmt .Sprintf ("RichMessage%+v" , Alias (*r ))
}
func (r *RichMessage ) FillFrom (from interface {
GetRtl () (value bool )
GetPart () (value bool )
GetBlocks () (value []PageBlockClass )
GetPhotos () (value []PhotoClass )
GetDocuments () (value []DocumentClass )
}) {
r .Rtl = from .GetRtl ()
r .Part = from .GetPart ()
r .Blocks = from .GetBlocks ()
r .Photos = from .GetPhotos ()
r .Documents = from .GetDocuments ()
}
func (*RichMessage ) TypeID () uint32 {
return RichMessageTypeID
}
func (*RichMessage ) TypeName () string {
return "richMessage"
}
func (r *RichMessage ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "richMessage" ,
ID : RichMessageTypeID ,
}
if r == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Rtl" ,
SchemaName : "rtl" ,
Null : !r .Flags .Has (0 ),
},
{
Name : "Part" ,
SchemaName : "part" ,
Null : !r .Flags .Has (1 ),
},
{
Name : "Blocks" ,
SchemaName : "blocks" ,
},
{
Name : "Photos" ,
SchemaName : "photos" ,
},
{
Name : "Documents" ,
SchemaName : "documents" ,
},
}
return typ
}
func (r *RichMessage ) SetFlags () {
if !(r .Rtl == false ) {
r .Flags .Set (0 )
}
if !(r .Part == false ) {
r .Flags .Set (1 )
}
}
func (r *RichMessage ) Encode (b *bin .Buffer ) error {
if r == nil {
return fmt .Errorf ("can't encode richMessage#baf39d8b as nil" )
}
b .PutID (RichMessageTypeID )
return r .EncodeBare (b )
}
func (r *RichMessage ) EncodeBare (b *bin .Buffer ) error {
if r == nil {
return fmt .Errorf ("can't encode richMessage#baf39d8b as nil" )
}
r .SetFlags ()
if err := r .Flags .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode richMessage#baf39d8b: field flags: %w" , err )
}
b .PutVectorHeader (len (r .Blocks ))
for idx , v := range r .Blocks {
if v == nil {
return fmt .Errorf ("unable to encode richMessage#baf39d8b: field blocks element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode richMessage#baf39d8b: field blocks element with index %d: %w" , idx , err )
}
}
b .PutVectorHeader (len (r .Photos ))
for idx , v := range r .Photos {
if v == nil {
return fmt .Errorf ("unable to encode richMessage#baf39d8b: field photos element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode richMessage#baf39d8b: field photos element with index %d: %w" , idx , err )
}
}
b .PutVectorHeader (len (r .Documents ))
for idx , v := range r .Documents {
if v == nil {
return fmt .Errorf ("unable to encode richMessage#baf39d8b: field documents element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode richMessage#baf39d8b: field documents element with index %d: %w" , idx , err )
}
}
return nil
}
func (r *RichMessage ) Decode (b *bin .Buffer ) error {
if r == nil {
return fmt .Errorf ("can't decode richMessage#baf39d8b to nil" )
}
if err := b .ConsumeID (RichMessageTypeID ); err != nil {
return fmt .Errorf ("unable to decode richMessage#baf39d8b: %w" , err )
}
return r .DecodeBare (b )
}
func (r *RichMessage ) DecodeBare (b *bin .Buffer ) error {
if r == nil {
return fmt .Errorf ("can't decode richMessage#baf39d8b to nil" )
}
{
if err := r .Flags .Decode (b ); err != nil {
return fmt .Errorf ("unable to decode richMessage#baf39d8b: field flags: %w" , err )
}
}
r .Rtl = r .Flags .Has (0 )
r .Part = r .Flags .Has (1 )
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode richMessage#baf39d8b: field blocks: %w" , err )
}
if headerLen > 0 {
r .Blocks = make ([]PageBlockClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodePageBlock (b )
if err != nil {
return fmt .Errorf ("unable to decode richMessage#baf39d8b: field blocks: %w" , err )
}
r .Blocks = append (r .Blocks , value )
}
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode richMessage#baf39d8b: field photos: %w" , err )
}
if headerLen > 0 {
r .Photos = make ([]PhotoClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodePhoto (b )
if err != nil {
return fmt .Errorf ("unable to decode richMessage#baf39d8b: field photos: %w" , err )
}
r .Photos = append (r .Photos , value )
}
}
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode richMessage#baf39d8b: field documents: %w" , err )
}
if headerLen > 0 {
r .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 richMessage#baf39d8b: field documents: %w" , err )
}
r .Documents = append (r .Documents , value )
}
}
return nil
}
func (r *RichMessage ) SetRtl (value bool ) {
if value {
r .Flags .Set (0 )
r .Rtl = true
} else {
r .Flags .Unset (0 )
r .Rtl = false
}
}
func (r *RichMessage ) GetRtl () (value bool ) {
if r == nil {
return
}
return r .Flags .Has (0 )
}
func (r *RichMessage ) SetPart (value bool ) {
if value {
r .Flags .Set (1 )
r .Part = true
} else {
r .Flags .Unset (1 )
r .Part = false
}
}
func (r *RichMessage ) GetPart () (value bool ) {
if r == nil {
return
}
return r .Flags .Has (1 )
}
func (r *RichMessage ) GetBlocks () (value []PageBlockClass ) {
if r == nil {
return
}
return r .Blocks
}
func (r *RichMessage ) GetPhotos () (value []PhotoClass ) {
if r == nil {
return
}
return r .Photos
}
func (r *RichMessage ) GetDocuments () (value []DocumentClass ) {
if r == nil {
return
}
return r .Documents
}
func (r *RichMessage ) MapBlocks () (value PageBlockClassArray ) {
return PageBlockClassArray (r .Blocks )
}
func (r *RichMessage ) MapPhotos () (value PhotoClassArray ) {
return PhotoClassArray (r .Photos )
}
func (r *RichMessage ) MapDocuments () (value DocumentClassArray ) {
return DocumentClassArray (r .Documents )
}
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 .