From da47444e7078a5a5109178ebd6c8b21218aba875 Mon Sep 17 00:00:00 2001 From: Temirkhan Myrzamadi Date: Wed, 29 Jul 2020 00:15:03 +0600 Subject: [PATCH] Describe the cargo features in README.md --- README.md | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 3ce52a91..4e95d660 100644 --- a/README.md +++ b/README.md @@ -22,18 +22,19 @@ ## Table of contents - - [Features](https://github.com/teloxide/teloxide#features) + - [Highlights](https://github.com/teloxide/teloxide#highlights) - [Setting up your environment](https://github.com/teloxide/teloxide#setting-up-your-environment) - [API overview](https://github.com/teloxide/teloxide#api-overview) - [The ping-pong bot](https://github.com/teloxide/teloxide#the-ping-pong-bot) - [Commands](https://github.com/teloxide/teloxide#commands) - [Dialogues management](https://github.com/teloxide/teloxide#dialogues-management) - [Recommendations](https://github.com/teloxide/teloxide#recommendations) + - [Cargo features](https://github.com/teloxide/teloxide#cargo-features) - [FAQ](https://github.com/teloxide/teloxide#faq) - [Community bots](https://github.com/teloxide/teloxide#community-bots) - [Contributing](https://github.com/teloxide/teloxide#contributing) -## Features +## Highlights - **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]. @@ -378,9 +379,20 @@ async fn handle_message(cx: UpdateWithCx, dialogue: Dialogue) -> Transi // Your logic here... } ``` - + The second one produces very strange compiler messages because of the `#[tokio::main]` macro. However, the examples in this README use the second variant for brevity. +## Cargo features + + - `redis-storage` -- enables the [Redis] support. + - `cbor-serializer` -- enables the [CBOR] serializer for dialogues. + - `bincode-serializer` -- enables the [Bincode] serializer for dialogues. + - `frunk` -- enables [`teloxide::utils::UpState`], which allows mapping from a structure of `field1, ..., fieldN` to a structure of `field1, ..., fieldN, fieldN+1`. + +[CBOR]: https://en.wikipedia.org/wiki/CBOR +[Bincode]: https://github.com/servo/bincode +[`teloxide::utils::UpState`]: https://docs.rs/teloxide/latest/teloxide/utils/trait.UpState.html + ## FAQ Q: Where I can ask questions?