# Parse modes
You may be familiar with parse modes from the Bot API. Indeed,
the idea is pretty much the same - parse mode defines the syntax to use
for formatting entities in messages.
However, there's a major difference – in mtcute, the client doesn't know anything about
how the parse modes are implemented. Instead, it just accepts an object containing
the `text` and `entities` fields, and sends it to the server:
```ts
await tg.sendText('self', {
text: 'Hi, User!',
entities: [
{ _: 'messageEntityBold', offset: 4, length: 4 }
]
})
```
Of course, passing this object manually is not very convenient,
so mtcute provides a set of *parsers* that can be used to convert
a string with entities to this structure.
For convenience, mtcute itself provides two parsers – for Markdown and HTML.
They are both implemented as separate packages, and they themselves are tagged template literals,
which makes it very easy to interpolate variables into the message.
## Markdown
Markdown parser is implemented in `@mtcute/markdown-parser` package:
```ts
import { md } from '@mtcute/markdown-parser'
dp.onNewMessage(async (msg) => {
await msg.answerText(md`Hello, **${msg.sender.username}**`)
})
```
**Note**: the syntax used by this parser is **not** compatible
with Bot API's Markdown or MarkdownV2 syntax.
See [documentation](https://ref.mtcute.dev/modules/_mtcute_markdown_parser.html)
to learn about the syntax.
## HTML
HTML parser is implemented in `@mtcute/html-parser` package:
```ts
import { html } from '@mtcute/html-parser'
dp.onNewMessage(async (msg) => {
await msg.answerText(html`Hello, ${msg.sender.username}`)
})
```
**Note**: the syntax used by this parser is **not**
compatible with Bot API's HTML syntax.
See [documentation](https://ref.mtcute.dev/modules/_mtcute_html_parser.html)
to learn about the syntax.
## Interpolation
Both parsers support interpolation of variables into the message,
as can be seen in the examples above.
Both parsers support the following types of interpolation:
- `string` - **will not** be parsed, and appended to plain text as-is
- `number` - will be converted to string and appended to plain text as-is
- `TextWithEntities` or `MessageEntity` - will add the text and its entities to the output.
This is the type returned by `md` and `html` themselves, so you can even mix and match them:
```ts
const greeting = (user) => html`${user.displayName}`
const text = md`**Hello**, ${user}!`
```
- falsy value (i.e. `null`, `undefined`, `false`) - will be ignored
### Unsafe interpolation
In some cases, you may already have a string with entities, and want to parse it to entities.
In this case, you can use the method as a function:
```ts
const text = 'Hello, **User**!'
await tg.sendText('self', md(text))
// or even
await tg.sendText('self', md`${md(text)} What's new?`)
```
## Un-parsing
Both HTML and Markdown parsers also provide an `unparse` method,
which can be used to convert the message back to the original text:
```ts
import { html } from '@mtcute/html-parser'
const msg = await tg.sendText('Hi, User!', { parseMode: 'html' })
console.log(msg.text)
// Hi, User!
console.log(html.unparse())
// Hi, User!
```