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 InputRichMessage struct {
Flags bin .Fields
Rtl bool
Noautolink bool
Blocks []PageBlockClass
Photos []InputPhotoClass
Documents []InputDocumentClass
Users []InputUserClass
}
const InputRichMessageTypeID = 0xe4c449fc
func (i InputRichMessage ) construct () InputRichMessageClass { return &i }
var (
_ bin .Encoder = &InputRichMessage {}
_ bin .Decoder = &InputRichMessage {}
_ bin .BareEncoder = &InputRichMessage {}
_ bin .BareDecoder = &InputRichMessage {}
_ InputRichMessageClass = &InputRichMessage {}
)
func (i *InputRichMessage ) Zero () bool {
if i == nil {
return true
}
if !(i .Flags .Zero ()) {
return false
}
if !(i .Rtl == false ) {
return false
}
if !(i .Noautolink == false ) {
return false
}
if !(i .Blocks == nil ) {
return false
}
if !(i .Photos == nil ) {
return false
}
if !(i .Documents == nil ) {
return false
}
if !(i .Users == nil ) {
return false
}
return true
}
func (i *InputRichMessage ) String () string {
if i == nil {
return "InputRichMessage(nil)"
}
type Alias InputRichMessage
return fmt .Sprintf ("InputRichMessage%+v" , Alias (*i ))
}
func (i *InputRichMessage ) FillFrom (from interface {
GetRtl () (value bool )
GetNoautolink () (value bool )
GetBlocks () (value []PageBlockClass )
GetPhotos () (value []InputPhotoClass , ok bool )
GetDocuments () (value []InputDocumentClass , ok bool )
GetUsers () (value []InputUserClass , ok bool )
}) {
i .Rtl = from .GetRtl ()
i .Noautolink = from .GetNoautolink ()
i .Blocks = from .GetBlocks ()
if val , ok := from .GetPhotos (); ok {
i .Photos = val
}
if val , ok := from .GetDocuments (); ok {
i .Documents = val
}
if val , ok := from .GetUsers (); ok {
i .Users = val
}
}
func (*InputRichMessage ) TypeID () uint32 {
return InputRichMessageTypeID
}
func (*InputRichMessage ) TypeName () string {
return "inputRichMessage"
}
func (i *InputRichMessage ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "inputRichMessage" ,
ID : InputRichMessageTypeID ,
}
if i == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Rtl" ,
SchemaName : "rtl" ,
Null : !i .Flags .Has (0 ),
},
{
Name : "Noautolink" ,
SchemaName : "noautolink" ,
Null : !i .Flags .Has (1 ),
},
{
Name : "Blocks" ,
SchemaName : "blocks" ,
},
{
Name : "Photos" ,
SchemaName : "photos" ,
Null : !i .Flags .Has (2 ),
},
{
Name : "Documents" ,
SchemaName : "documents" ,
Null : !i .Flags .Has (3 ),
},
{
Name : "Users" ,
SchemaName : "users" ,
Null : !i .Flags .Has (4 ),
},
}
return typ
}
func (i *InputRichMessage ) SetFlags () {
if !(i .Rtl == false ) {
i .Flags .Set (0 )
}
if !(i .Noautolink == false ) {
i .Flags .Set (1 )
}
if !(i .Photos == nil ) {
i .Flags .Set (2 )
}
if !(i .Documents == nil ) {
i .Flags .Set (3 )
}
if !(i .Users == nil ) {
i .Flags .Set (4 )
}
}
func (i *InputRichMessage ) Encode (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't encode inputRichMessage#e4c449fc as nil" )
}
b .PutID (InputRichMessageTypeID )
return i .EncodeBare (b )
}
func (i *InputRichMessage ) EncodeBare (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't encode inputRichMessage#e4c449fc as nil" )
}
i .SetFlags ()
if err := i .Flags .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field flags: %w" , err )
}
b .PutVectorHeader (len (i .Blocks ))
for idx , v := range i .Blocks {
if v == nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field blocks element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field blocks element with index %d: %w" , idx , err )
}
}
if i .Flags .Has (2 ) {
b .PutVectorHeader (len (i .Photos ))
for idx , v := range i .Photos {
if v == nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field photos element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field photos element with index %d: %w" , idx , err )
}
}
}
if i .Flags .Has (3 ) {
b .PutVectorHeader (len (i .Documents ))
for idx , v := range i .Documents {
if v == nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field documents element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field documents element with index %d: %w" , idx , err )
}
}
}
if i .Flags .Has (4 ) {
b .PutVectorHeader (len (i .Users ))
for idx , v := range i .Users {
if v == nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field users element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessage#e4c449fc: field users element with index %d: %w" , idx , err )
}
}
}
return nil
}
func (i *InputRichMessage ) Decode (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't decode inputRichMessage#e4c449fc to nil" )
}
if err := b .ConsumeID (InputRichMessageTypeID ); err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: %w" , err )
}
return i .DecodeBare (b )
}
func (i *InputRichMessage ) DecodeBare (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't decode inputRichMessage#e4c449fc to nil" )
}
{
if err := i .Flags .Decode (b ); err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: field flags: %w" , err )
}
}
i .Rtl = i .Flags .Has (0 )
i .Noautolink = i .Flags .Has (1 )
{
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: field blocks: %w" , err )
}
if headerLen > 0 {
i .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 inputRichMessage#e4c449fc: field blocks: %w" , err )
}
i .Blocks = append (i .Blocks , value )
}
}
if i .Flags .Has (2 ) {
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: field photos: %w" , err )
}
if headerLen > 0 {
i .Photos = make ([]InputPhotoClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeInputPhoto (b )
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: field photos: %w" , err )
}
i .Photos = append (i .Photos , value )
}
}
if i .Flags .Has (3 ) {
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: field documents: %w" , err )
}
if headerLen > 0 {
i .Documents = make ([]InputDocumentClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeInputDocument (b )
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: field documents: %w" , err )
}
i .Documents = append (i .Documents , value )
}
}
if i .Flags .Has (4 ) {
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: field users: %w" , err )
}
if headerLen > 0 {
i .Users = make ([]InputUserClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeInputUser (b )
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessage#e4c449fc: field users: %w" , err )
}
i .Users = append (i .Users , value )
}
}
return nil
}
func (i *InputRichMessage ) SetRtl (value bool ) {
if value {
i .Flags .Set (0 )
i .Rtl = true
} else {
i .Flags .Unset (0 )
i .Rtl = false
}
}
func (i *InputRichMessage ) GetRtl () (value bool ) {
if i == nil {
return
}
return i .Flags .Has (0 )
}
func (i *InputRichMessage ) SetNoautolink (value bool ) {
if value {
i .Flags .Set (1 )
i .Noautolink = true
} else {
i .Flags .Unset (1 )
i .Noautolink = false
}
}
func (i *InputRichMessage ) GetNoautolink () (value bool ) {
if i == nil {
return
}
return i .Flags .Has (1 )
}
func (i *InputRichMessage ) GetBlocks () (value []PageBlockClass ) {
if i == nil {
return
}
return i .Blocks
}
func (i *InputRichMessage ) SetPhotos (value []InputPhotoClass ) {
i .Flags .Set (2 )
i .Photos = value
}
func (i *InputRichMessage ) GetPhotos () (value []InputPhotoClass , ok bool ) {
if i == nil {
return
}
if !i .Flags .Has (2 ) {
return value , false
}
return i .Photos , true
}
func (i *InputRichMessage ) SetDocuments (value []InputDocumentClass ) {
i .Flags .Set (3 )
i .Documents = value
}
func (i *InputRichMessage ) GetDocuments () (value []InputDocumentClass , ok bool ) {
if i == nil {
return
}
if !i .Flags .Has (3 ) {
return value , false
}
return i .Documents , true
}
func (i *InputRichMessage ) SetUsers (value []InputUserClass ) {
i .Flags .Set (4 )
i .Users = value
}
func (i *InputRichMessage ) GetUsers () (value []InputUserClass , ok bool ) {
if i == nil {
return
}
if !i .Flags .Has (4 ) {
return value , false
}
return i .Users , true
}
func (i *InputRichMessage ) MapBlocks () (value PageBlockClassArray ) {
return PageBlockClassArray (i .Blocks )
}
func (i *InputRichMessage ) MapPhotos () (value InputPhotoClassArray , ok bool ) {
if !i .Flags .Has (2 ) {
return value , false
}
return InputPhotoClassArray (i .Photos ), true
}
func (i *InputRichMessage ) MapDocuments () (value InputDocumentClassArray , ok bool ) {
if !i .Flags .Has (3 ) {
return value , false
}
return InputDocumentClassArray (i .Documents ), true
}
func (i *InputRichMessage ) MapUsers () (value InputUserClassArray , ok bool ) {
if !i .Flags .Has (4 ) {
return value , false
}
return InputUserClassArray (i .Users ), true
}
type InputRichMessageHTML struct {
Flags bin .Fields
Rtl bool
Noautolink bool
HTML string
Files []InputRichFileClass
}
const InputRichMessageHTMLTypeID = 0xdacb836a
func (i InputRichMessageHTML ) construct () InputRichMessageClass { return &i }
var (
_ bin .Encoder = &InputRichMessageHTML {}
_ bin .Decoder = &InputRichMessageHTML {}
_ bin .BareEncoder = &InputRichMessageHTML {}
_ bin .BareDecoder = &InputRichMessageHTML {}
_ InputRichMessageClass = &InputRichMessageHTML {}
)
func (i *InputRichMessageHTML ) Zero () bool {
if i == nil {
return true
}
if !(i .Flags .Zero ()) {
return false
}
if !(i .Rtl == false ) {
return false
}
if !(i .Noautolink == false ) {
return false
}
if !(i .HTML == "" ) {
return false
}
if !(i .Files == nil ) {
return false
}
return true
}
func (i *InputRichMessageHTML ) String () string {
if i == nil {
return "InputRichMessageHTML(nil)"
}
type Alias InputRichMessageHTML
return fmt .Sprintf ("InputRichMessageHTML%+v" , Alias (*i ))
}
func (i *InputRichMessageHTML ) FillFrom (from interface {
GetRtl () (value bool )
GetNoautolink () (value bool )
GetHTML () (value string )
GetFiles () (value []InputRichFileClass , ok bool )
}) {
i .Rtl = from .GetRtl ()
i .Noautolink = from .GetNoautolink ()
i .HTML = from .GetHTML ()
if val , ok := from .GetFiles (); ok {
i .Files = val
}
}
func (*InputRichMessageHTML ) TypeID () uint32 {
return InputRichMessageHTMLTypeID
}
func (*InputRichMessageHTML ) TypeName () string {
return "inputRichMessageHTML"
}
func (i *InputRichMessageHTML ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "inputRichMessageHTML" ,
ID : InputRichMessageHTMLTypeID ,
}
if i == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Rtl" ,
SchemaName : "rtl" ,
Null : !i .Flags .Has (0 ),
},
{
Name : "Noautolink" ,
SchemaName : "noautolink" ,
Null : !i .Flags .Has (1 ),
},
{
Name : "HTML" ,
SchemaName : "html" ,
},
{
Name : "Files" ,
SchemaName : "files" ,
Null : !i .Flags .Has (2 ),
},
}
return typ
}
func (i *InputRichMessageHTML ) SetFlags () {
if !(i .Rtl == false ) {
i .Flags .Set (0 )
}
if !(i .Noautolink == false ) {
i .Flags .Set (1 )
}
if !(i .Files == nil ) {
i .Flags .Set (2 )
}
}
func (i *InputRichMessageHTML ) Encode (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't encode inputRichMessageHTML#dacb836a as nil" )
}
b .PutID (InputRichMessageHTMLTypeID )
return i .EncodeBare (b )
}
func (i *InputRichMessageHTML ) EncodeBare (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't encode inputRichMessageHTML#dacb836a as nil" )
}
i .SetFlags ()
if err := i .Flags .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessageHTML#dacb836a: field flags: %w" , err )
}
b .PutString (i .HTML )
if i .Flags .Has (2 ) {
b .PutVectorHeader (len (i .Files ))
for idx , v := range i .Files {
if v == nil {
return fmt .Errorf ("unable to encode inputRichMessageHTML#dacb836a: field files element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessageHTML#dacb836a: field files element with index %d: %w" , idx , err )
}
}
}
return nil
}
func (i *InputRichMessageHTML ) Decode (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't decode inputRichMessageHTML#dacb836a to nil" )
}
if err := b .ConsumeID (InputRichMessageHTMLTypeID ); err != nil {
return fmt .Errorf ("unable to decode inputRichMessageHTML#dacb836a: %w" , err )
}
return i .DecodeBare (b )
}
func (i *InputRichMessageHTML ) DecodeBare (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't decode inputRichMessageHTML#dacb836a to nil" )
}
{
if err := i .Flags .Decode (b ); err != nil {
return fmt .Errorf ("unable to decode inputRichMessageHTML#dacb836a: field flags: %w" , err )
}
}
i .Rtl = i .Flags .Has (0 )
i .Noautolink = i .Flags .Has (1 )
{
value , err := b .String ()
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessageHTML#dacb836a: field html: %w" , err )
}
i .HTML = value
}
if i .Flags .Has (2 ) {
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessageHTML#dacb836a: field files: %w" , err )
}
if headerLen > 0 {
i .Files = make ([]InputRichFileClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeInputRichFile (b )
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessageHTML#dacb836a: field files: %w" , err )
}
i .Files = append (i .Files , value )
}
}
return nil
}
func (i *InputRichMessageHTML ) SetRtl (value bool ) {
if value {
i .Flags .Set (0 )
i .Rtl = true
} else {
i .Flags .Unset (0 )
i .Rtl = false
}
}
func (i *InputRichMessageHTML ) GetRtl () (value bool ) {
if i == nil {
return
}
return i .Flags .Has (0 )
}
func (i *InputRichMessageHTML ) SetNoautolink (value bool ) {
if value {
i .Flags .Set (1 )
i .Noautolink = true
} else {
i .Flags .Unset (1 )
i .Noautolink = false
}
}
func (i *InputRichMessageHTML ) GetNoautolink () (value bool ) {
if i == nil {
return
}
return i .Flags .Has (1 )
}
func (i *InputRichMessageHTML ) GetHTML () (value string ) {
if i == nil {
return
}
return i .HTML
}
func (i *InputRichMessageHTML ) SetFiles (value []InputRichFileClass ) {
i .Flags .Set (2 )
i .Files = value
}
func (i *InputRichMessageHTML ) GetFiles () (value []InputRichFileClass , ok bool ) {
if i == nil {
return
}
if !i .Flags .Has (2 ) {
return value , false
}
return i .Files , true
}
func (i *InputRichMessageHTML ) MapFiles () (value InputRichFileClassArray , ok bool ) {
if !i .Flags .Has (2 ) {
return value , false
}
return InputRichFileClassArray (i .Files ), true
}
type InputRichMessageMarkdown struct {
Flags bin .Fields
Rtl bool
Noautolink bool
Markdown string
Files []InputRichFileClass
}
const InputRichMessageMarkdownTypeID = 0x4b572c
func (i InputRichMessageMarkdown ) construct () InputRichMessageClass { return &i }
var (
_ bin .Encoder = &InputRichMessageMarkdown {}
_ bin .Decoder = &InputRichMessageMarkdown {}
_ bin .BareEncoder = &InputRichMessageMarkdown {}
_ bin .BareDecoder = &InputRichMessageMarkdown {}
_ InputRichMessageClass = &InputRichMessageMarkdown {}
)
func (i *InputRichMessageMarkdown ) Zero () bool {
if i == nil {
return true
}
if !(i .Flags .Zero ()) {
return false
}
if !(i .Rtl == false ) {
return false
}
if !(i .Noautolink == false ) {
return false
}
if !(i .Markdown == "" ) {
return false
}
if !(i .Files == nil ) {
return false
}
return true
}
func (i *InputRichMessageMarkdown ) String () string {
if i == nil {
return "InputRichMessageMarkdown(nil)"
}
type Alias InputRichMessageMarkdown
return fmt .Sprintf ("InputRichMessageMarkdown%+v" , Alias (*i ))
}
func (i *InputRichMessageMarkdown ) FillFrom (from interface {
GetRtl () (value bool )
GetNoautolink () (value bool )
GetMarkdown () (value string )
GetFiles () (value []InputRichFileClass , ok bool )
}) {
i .Rtl = from .GetRtl ()
i .Noautolink = from .GetNoautolink ()
i .Markdown = from .GetMarkdown ()
if val , ok := from .GetFiles (); ok {
i .Files = val
}
}
func (*InputRichMessageMarkdown ) TypeID () uint32 {
return InputRichMessageMarkdownTypeID
}
func (*InputRichMessageMarkdown ) TypeName () string {
return "inputRichMessageMarkdown"
}
func (i *InputRichMessageMarkdown ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "inputRichMessageMarkdown" ,
ID : InputRichMessageMarkdownTypeID ,
}
if i == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Rtl" ,
SchemaName : "rtl" ,
Null : !i .Flags .Has (0 ),
},
{
Name : "Noautolink" ,
SchemaName : "noautolink" ,
Null : !i .Flags .Has (1 ),
},
{
Name : "Markdown" ,
SchemaName : "markdown" ,
},
{
Name : "Files" ,
SchemaName : "files" ,
Null : !i .Flags .Has (2 ),
},
}
return typ
}
func (i *InputRichMessageMarkdown ) SetFlags () {
if !(i .Rtl == false ) {
i .Flags .Set (0 )
}
if !(i .Noautolink == false ) {
i .Flags .Set (1 )
}
if !(i .Files == nil ) {
i .Flags .Set (2 )
}
}
func (i *InputRichMessageMarkdown ) Encode (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't encode inputRichMessageMarkdown#4b572c as nil" )
}
b .PutID (InputRichMessageMarkdownTypeID )
return i .EncodeBare (b )
}
func (i *InputRichMessageMarkdown ) EncodeBare (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't encode inputRichMessageMarkdown#4b572c as nil" )
}
i .SetFlags ()
if err := i .Flags .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessageMarkdown#4b572c: field flags: %w" , err )
}
b .PutString (i .Markdown )
if i .Flags .Has (2 ) {
b .PutVectorHeader (len (i .Files ))
for idx , v := range i .Files {
if v == nil {
return fmt .Errorf ("unable to encode inputRichMessageMarkdown#4b572c: field files element with index %d is nil" , idx )
}
if err := v .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode inputRichMessageMarkdown#4b572c: field files element with index %d: %w" , idx , err )
}
}
}
return nil
}
func (i *InputRichMessageMarkdown ) Decode (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't decode inputRichMessageMarkdown#4b572c to nil" )
}
if err := b .ConsumeID (InputRichMessageMarkdownTypeID ); err != nil {
return fmt .Errorf ("unable to decode inputRichMessageMarkdown#4b572c: %w" , err )
}
return i .DecodeBare (b )
}
func (i *InputRichMessageMarkdown ) DecodeBare (b *bin .Buffer ) error {
if i == nil {
return fmt .Errorf ("can't decode inputRichMessageMarkdown#4b572c to nil" )
}
{
if err := i .Flags .Decode (b ); err != nil {
return fmt .Errorf ("unable to decode inputRichMessageMarkdown#4b572c: field flags: %w" , err )
}
}
i .Rtl = i .Flags .Has (0 )
i .Noautolink = i .Flags .Has (1 )
{
value , err := b .String ()
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessageMarkdown#4b572c: field markdown: %w" , err )
}
i .Markdown = value
}
if i .Flags .Has (2 ) {
headerLen , err := b .VectorHeader ()
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessageMarkdown#4b572c: field files: %w" , err )
}
if headerLen > 0 {
i .Files = make ([]InputRichFileClass , 0 , headerLen %bin .PreallocateLimit )
}
for idx := 0 ; idx < headerLen ; idx ++ {
value , err := DecodeInputRichFile (b )
if err != nil {
return fmt .Errorf ("unable to decode inputRichMessageMarkdown#4b572c: field files: %w" , err )
}
i .Files = append (i .Files , value )
}
}
return nil
}
func (i *InputRichMessageMarkdown ) SetRtl (value bool ) {
if value {
i .Flags .Set (0 )
i .Rtl = true
} else {
i .Flags .Unset (0 )
i .Rtl = false
}
}
func (i *InputRichMessageMarkdown ) GetRtl () (value bool ) {
if i == nil {
return
}
return i .Flags .Has (0 )
}
func (i *InputRichMessageMarkdown ) SetNoautolink (value bool ) {
if value {
i .Flags .Set (1 )
i .Noautolink = true
} else {
i .Flags .Unset (1 )
i .Noautolink = false
}
}
func (i *InputRichMessageMarkdown ) GetNoautolink () (value bool ) {
if i == nil {
return
}
return i .Flags .Has (1 )
}
func (i *InputRichMessageMarkdown ) GetMarkdown () (value string ) {
if i == nil {
return
}
return i .Markdown
}
func (i *InputRichMessageMarkdown ) SetFiles (value []InputRichFileClass ) {
i .Flags .Set (2 )
i .Files = value
}
func (i *InputRichMessageMarkdown ) GetFiles () (value []InputRichFileClass , ok bool ) {
if i == nil {
return
}
if !i .Flags .Has (2 ) {
return value , false
}
return i .Files , true
}
func (i *InputRichMessageMarkdown ) MapFiles () (value InputRichFileClassArray , ok bool ) {
if !i .Flags .Has (2 ) {
return value , false
}
return InputRichFileClassArray (i .Files ), true
}
const InputRichMessageClassName = "InputRichMessage"
type InputRichMessageClass interface {
bin .Encoder
bin .Decoder
bin .BareEncoder
bin .BareDecoder
construct () InputRichMessageClass
TypeID () uint32
TypeName () string
String () string
Zero () bool
GetRtl () (value bool )
GetNoautolink () (value bool )
}
func DecodeInputRichMessage (buf *bin .Buffer ) (InputRichMessageClass , error ) {
id , err := buf .PeekID ()
if err != nil {
return nil , err
}
switch id {
case InputRichMessageTypeID :
v := InputRichMessage {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode InputRichMessageClass: %w" , err )
}
return &v , nil
case InputRichMessageHTMLTypeID :
v := InputRichMessageHTML {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode InputRichMessageClass: %w" , err )
}
return &v , nil
case InputRichMessageMarkdownTypeID :
v := InputRichMessageMarkdown {}
if err := v .Decode (buf ); err != nil {
return nil , fmt .Errorf ("unable to decode InputRichMessageClass: %w" , err )
}
return &v , nil
default :
return nil , fmt .Errorf ("unable to decode InputRichMessageClass: %w" , bin .NewUnexpectedID (id ))
}
}
type InputRichMessageBox struct {
InputRichMessage InputRichMessageClass
}
func (b *InputRichMessageBox ) Decode (buf *bin .Buffer ) error {
if b == nil {
return fmt .Errorf ("unable to decode InputRichMessageBox to nil" )
}
v , err := DecodeInputRichMessage (buf )
if err != nil {
return fmt .Errorf ("unable to decode boxed value: %w" , err )
}
b .InputRichMessage = v
return nil
}
func (b *InputRichMessageBox ) Encode (buf *bin .Buffer ) error {
if b == nil || b .InputRichMessage == nil {
return fmt .Errorf ("unable to encode InputRichMessageClass as nil" )
}
return b .InputRichMessage .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 .