mirror of
https://github.com/teloxide/teloxide.git
synced 2024-12-31 16:40:37 +01:00
Rework the 'Features' section (README.md)
This commit is contained in:
parent
d6298c2329
commit
0c965473a2
1 changed files with 9 additions and 22 deletions
31
README.md
31
README.md
|
@ -35,33 +35,20 @@
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
<h3 align="center">Functional reactive design</h3>
|
- **Functioal reactive design.** teloxide has [functional reactive design], allowing you to declaratively manipulate streams of updates from Telegram using filters, maps, folds, zips, and a lot of [other adaptors].
|
||||||
<p align="center">
|
|
||||||
teloxide has <a href="https://en.wikipedia.org/wiki/Functional_reactive_programming">functional reactive design</a>, allowing you to declaratively manipulate streams of updates from Telegram using filters, maps, folds, zips, and a lot of <a href="https://docs.rs/futures/latest/futures/stream/trait.StreamExt.html">other adaptors</a>.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<hr>
|
[functional reactive design]: https://en.wikipedia.org/wiki/Functional_reactive_programming
|
||||||
|
[other adaptors]: https://docs.rs/futures/latest/futures/stream/trait.StreamExt.html
|
||||||
|
|
||||||
<h3 align="center">API types as ADTs</h3>
|
- **Persistence.** Dialogues management is independent of how/where dialogues are stored: you can just replace one line and make them [persistent]. Out-of-the-box storages include [Redis].
|
||||||
<p align="center">
|
|
||||||
All the API <a href="https://docs.rs/teloxide/latest/teloxide/types/index.html">types</a> and <a href="https://docs.rs/teloxide/latest/teloxide/requests/index.html">methods</a> are hand-written, with heavy use of <a href="https://en.wikipedia.org/wiki/Algebraic_data_type"><strong>ADT</strong>s</a> (algebraic data types) to enforce type safety and tight integration with IDEs. As few <code>Option</code>s as possible.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<hr>
|
[persistent]: https://en.wikipedia.org/wiki/Persistence_(computer_science)
|
||||||
|
[Redis]: https://redis.io/
|
||||||
|
|
||||||
<h3 align="center">Persistence</h3>
|
- **Strongly typed bot commands.** You can describe bot commands as enumerations, and then they'll be automatically constructed from strings. Just like you describe JSON structures in [serde-json] and command-line arguments in [structopt].
|
||||||
<p align="center">
|
|
||||||
Dialogues management is independent of how/where dialogues are stored: you can just replace one line and make them <a href="https://en.wikipedia.org/wiki/Persistence_(computer_science)">persistent</a>. Out-of-the-box storages include <a href="https://redis.io/">Redis</a>.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<hr>
|
[structopt]: https://github.com/TeXitoi/structopt
|
||||||
|
[serde-json]: https://github.com/serde-rs/json
|
||||||
<h3 align="center">Strongly typed bot commands</h3>
|
|
||||||
<p align="center">
|
|
||||||
You can describe bot commands as enumerations, and then they'll be automatically constructed from strings. Just like you describe JSON structures in <a href="https://github.com/serde-rs/json">serde-json</a> and command-line arguments in <a href="https://github.com/TeXitoi/structopt">structopt</a>.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<hr>
|
|
||||||
|
|
||||||
## Setting up your environment
|
## Setting up your environment
|
||||||
1. [Download Rust](http://rustup.rs/).
|
1. [Download Rust](http://rustup.rs/).
|
||||||
|
|
Loading…
Reference in a new issue