mtcute/packages/tl-utils/src/stringify.ts

65 lines
1.6 KiB
TypeScript
Raw Normal View History

import type { TlEntry } from './types.js'
import { stringifyArgumentType } from './utils.js'
function normalizeType(s: string): string {
return s
2023-09-24 19:56:13 +03:00
.replace(/(?<=^|\?)bytes/, 'string')
.replace(/</g, ' ')
.replace(/>/g, '')
.replace('int53', 'long')
}
2022-08-29 14:33:11 +03:00
/**
* Generate TL definition for a given entry.
*
* @param entry Entry to generate definition for
* @param forIdComputation
* Whether to generate definition for constructor ID computation
* (it has slightly different syntax, will not contain `true` flags, etc.)
*/
2023-09-24 01:32:22 +03:00
export function writeTlEntryToString(entry: TlEntry, forIdComputation = false): string {
let str = entry.name
if (!forIdComputation && entry.id) {
str += `#${entry.id.toString(16)}`
}
str += ' '
if (entry.generics) {
for (const g of entry.generics) {
if (forIdComputation) {
str += `${g.name}:${g.type} `
} else {
str += `{${g.name}:${g.type}} `
}
}
}
for (const arg of entry.arguments) {
2023-09-24 01:32:22 +03:00
if (forIdComputation && arg.typeModifiers?.predicate && arg.type === 'true') {
continue
}
str += `${arg.name}:`
const type = stringifyArgumentType(arg.type, arg.typeModifiers)
if (forIdComputation) {
str += `${normalizeType(type)} `
} else {
str += `${type} `
}
}
2023-09-24 19:56:13 +03:00
const type = entry.typeModifiers ? stringifyArgumentType(entry.type, entry.typeModifiers) : entry.type
if (forIdComputation) {
str += `= ${normalizeType(type)}`
} else {
str += `= ${type};`
}
return str
}