mirror of
https://github.com/teloxide/teloxide.git
synced 2025-01-24 09:16:12 +01:00
remove old_dispatching
feature, add prelude2
and repls2
modules
This commit is contained in:
parent
a8098350fc
commit
d7386a7dc1
20 changed files with 56 additions and 52 deletions
|
@ -12,10 +12,9 @@ license = "MIT"
|
||||||
exclude = ["media"]
|
exclude = ["media"]
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = ["native-tls", "ctrlc_handler", "teloxide-core/default", "auto-send", "new-dispatching"]
|
default = ["native-tls", "ctrlc_handler", "teloxide-core/default", "auto-send", "dispatching2"]
|
||||||
|
|
||||||
old-dispatching = []
|
dispatching2 = ["dptree"]
|
||||||
new-dispatching = ["dptree"]
|
|
||||||
|
|
||||||
sqlite-storage = ["sqlx"]
|
sqlite-storage = ["sqlx"]
|
||||||
redis-storage = ["redis"]
|
redis-storage = ["redis"]
|
||||||
|
|
|
@ -2,7 +2,7 @@ use std::{error::Error, str::FromStr};
|
||||||
|
|
||||||
use chrono::{DateTime, Duration, NaiveDateTime, Utc};
|
use chrono::{DateTime, Duration, NaiveDateTime, Utc};
|
||||||
use teloxide::{
|
use teloxide::{
|
||||||
prelude::*,
|
prelude2::*,
|
||||||
types::{ChatPermissions, Me},
|
types::{ChatPermissions, Me},
|
||||||
utils::command::BotCommand,
|
utils::command::BotCommand,
|
||||||
};
|
};
|
||||||
|
@ -162,5 +162,5 @@ async fn main() {
|
||||||
|
|
||||||
let Me { user: bot_user, .. } = bot.get_me().await.unwrap();
|
let Me { user: bot_user, .. } = bot.get_me().await.unwrap();
|
||||||
let bot_name = bot_user.username.expect("Bots must have usernames");
|
let bot_name = bot_user.username.expect("Bots must have usernames");
|
||||||
teloxide::commands_repl(bot, bot_name, action, Command::ty()).await;
|
teloxide::repls2::commands_repl(bot, bot_name, action, Command::ty()).await;
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,15 +11,10 @@ teloxide = { path = "../../", features = ["frunk", "macros", "sqlite-storage"] }
|
||||||
anyhow = "1.0.52"
|
anyhow = "1.0.52"
|
||||||
serde = "1"
|
serde = "1"
|
||||||
|
|
||||||
futures = "0.3.5"
|
|
||||||
tokio = { version = "1.3.0", features = ["rt-multi-thread", "macros"] }
|
tokio = { version = "1.3.0", features = ["rt-multi-thread", "macros"] }
|
||||||
|
|
||||||
log = "0.4.8"
|
log = "0.4.8"
|
||||||
pretty_env_logger = "0.4.0"
|
pretty_env_logger = "0.4.0"
|
||||||
derive_more = "0.99.9"
|
|
||||||
|
|
||||||
frunk = "0.4"
|
|
||||||
frunk_core = "0.4"
|
|
||||||
|
|
||||||
[profile.release]
|
[profile.release]
|
||||||
lto = true
|
lto = true
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
use teloxide::{
|
use teloxide::{
|
||||||
dispatching2::dialogue::{serializer::Json, SqliteStorage},
|
dispatching2::dialogue::{serializer::Json, SqliteStorage},
|
||||||
macros::DialogueState,
|
macros::DialogueState,
|
||||||
prelude::*,
|
prelude2::*,
|
||||||
};
|
};
|
||||||
|
|
||||||
// FIXME: naming
|
// FIXME: naming
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
// This bot throws a dice on each incoming message.
|
// This bot throws a dice on each incoming message.
|
||||||
|
|
||||||
use teloxide::prelude::*;
|
use teloxide::prelude2::*;
|
||||||
|
|
||||||
type TeleBot = AutoSend<Bot>;
|
type TeleBot = AutoSend<Bot>;
|
||||||
|
|
||||||
|
@ -11,7 +11,7 @@ async fn main() {
|
||||||
|
|
||||||
let bot = Bot::from_env().auto_send();
|
let bot = Bot::from_env().auto_send();
|
||||||
|
|
||||||
teloxide::repl(bot, |message: Message, bot: TeleBot| async move {
|
teloxide::repls2::repl(bot, |message: Message, bot: TeleBot| async move {
|
||||||
bot.send_dice(message.chat.id).await?;
|
bot.send_dice(message.chat.id).await?;
|
||||||
respond(())
|
respond(())
|
||||||
})
|
})
|
||||||
|
|
|
@ -6,7 +6,7 @@ use teloxide::{
|
||||||
stop_token::AsyncStopToken,
|
stop_token::AsyncStopToken,
|
||||||
update_listeners::{self, StatefulListener},
|
update_listeners::{self, StatefulListener},
|
||||||
},
|
},
|
||||||
prelude::*,
|
prelude2::*,
|
||||||
types::Update,
|
types::Update,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ async fn main() {
|
||||||
|
|
||||||
let bot = Bot::from_env().auto_send();
|
let bot = Bot::from_env().auto_send();
|
||||||
|
|
||||||
teloxide::repl_with_listener(
|
teloxide::repls2::repl_with_listener(
|
||||||
bot.clone(),
|
bot.clone(),
|
||||||
|mes: Message, bot: AutoSend<Bot>| async move {
|
|mes: Message, bot: AutoSend<Bot>| async move {
|
||||||
bot.send_message(mes.chat.id, "pong").await?;
|
bot.send_message(mes.chat.id, "pong").await?;
|
||||||
|
|
|
@ -11,4 +11,3 @@ teloxide = { path = "../../", features = ["macros"] }
|
||||||
log = "0.4.8"
|
log = "0.4.8"
|
||||||
pretty_env_logger = "0.4.0"
|
pretty_env_logger = "0.4.0"
|
||||||
tokio = { version = "1.3.0", features = ["rt-multi-thread", "macros"] }
|
tokio = { version = "1.3.0", features = ["rt-multi-thread", "macros"] }
|
||||||
tokio-stream = "0.1.3"
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
use teloxide::{
|
use teloxide::{
|
||||||
prelude::*,
|
prelude2::*,
|
||||||
types::{
|
types::{
|
||||||
InlineQueryResult, InlineQueryResultArticle, InputMessageContent, InputMessageContentText,
|
InlineQueryResult, InlineQueryResultArticle, InputMessageContent, InputMessageContentText,
|
||||||
},
|
},
|
||||||
|
|
|
@ -6,7 +6,7 @@ use teloxide::{
|
||||||
stop_token::AsyncStopToken,
|
stop_token::AsyncStopToken,
|
||||||
update_listeners::{self, StatefulListener},
|
update_listeners::{self, StatefulListener},
|
||||||
},
|
},
|
||||||
prelude::*,
|
prelude2::*,
|
||||||
types::Update,
|
types::Update,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ async fn main() {
|
||||||
|
|
||||||
let bot = Bot::from_env().auto_send();
|
let bot = Bot::from_env().auto_send();
|
||||||
|
|
||||||
teloxide::repl_with_listener(
|
teloxide::repls2::repl_with_listener(
|
||||||
bot.clone(),
|
bot.clone(),
|
||||||
|mes: Message, bot: AutoSend<Bot>| async move {
|
|mes: Message, bot: AutoSend<Bot>| async move {
|
||||||
bot.send_message(mes.chat.id, "pong").await?;
|
bot.send_message(mes.chat.id, "pong").await?;
|
||||||
|
|
|
@ -13,7 +13,4 @@ pretty_env_logger = "0.4.0"
|
||||||
tokio = { version = "1.3.0", features = ["rt-multi-thread", "macros"] }
|
tokio = { version = "1.3.0", features = ["rt-multi-thread", "macros"] }
|
||||||
|
|
||||||
serde = "1.0.104"
|
serde = "1.0.104"
|
||||||
futures = "0.3.5"
|
|
||||||
|
|
||||||
thiserror = "1.0.15"
|
thiserror = "1.0.15"
|
||||||
derive_more = "0.99.9"
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
use teloxide::{
|
use teloxide::{
|
||||||
dispatching2::dialogue::{serializer::Bincode, RedisStorage, Storage},
|
dispatching2::dialogue::{serializer::Bincode, RedisStorage, Storage},
|
||||||
prelude::*,
|
prelude2::*,
|
||||||
RequestError,
|
RequestError,
|
||||||
};
|
};
|
||||||
use thiserror::Error;
|
use thiserror::Error;
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
use std::sync::atomic::{AtomicU64, Ordering};
|
use std::sync::atomic::{AtomicU64, Ordering};
|
||||||
|
|
||||||
use lazy_static::lazy_static;
|
use lazy_static::lazy_static;
|
||||||
use teloxide::prelude::*;
|
use teloxide::prelude2::*;
|
||||||
|
|
||||||
lazy_static! {
|
lazy_static! {
|
||||||
static ref MESSAGES_TOTAL: AtomicU64 = AtomicU64::new(0);
|
static ref MESSAGES_TOTAL: AtomicU64 = AtomicU64::new(0);
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use teloxide::{prelude::*, utils::command::BotCommand};
|
use teloxide::{prelude2::*, utils::command::BotCommand};
|
||||||
|
|
||||||
use std::error::Error;
|
use std::error::Error;
|
||||||
use teloxide::types::Me;
|
use teloxide::types::Me;
|
||||||
|
@ -46,5 +46,5 @@ async fn main() {
|
||||||
let Me { user: bot_user, .. } = bot.get_me().await.unwrap();
|
let Me { user: bot_user, .. } = bot.get_me().await.unwrap();
|
||||||
let bot_name = bot_user.username.expect("Bots must have usernames");
|
let bot_name = bot_user.username.expect("Bots must have usernames");
|
||||||
|
|
||||||
teloxide::commands_repl(bot, bot_name, answer, Command::ty()).await;
|
teloxide::repls2::commands_repl(bot, bot_name, answer, Command::ty()).await;
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,6 +13,4 @@ pretty_env_logger = "0.4.0"
|
||||||
tokio = { version = "1.3.0", features = ["rt-multi-thread", "macros"] }
|
tokio = { version = "1.3.0", features = ["rt-multi-thread", "macros"] }
|
||||||
|
|
||||||
serde = "1.0.104"
|
serde = "1.0.104"
|
||||||
futures = "0.3.5"
|
|
||||||
|
|
||||||
thiserror = "1.0.15"
|
thiserror = "1.0.15"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use teloxide::{
|
use teloxide::{
|
||||||
dispatching2::dialogue::{serializer::Json, SqliteStorage, Storage},
|
dispatching2::dialogue::{serializer::Json, SqliteStorage, Storage},
|
||||||
prelude::*,
|
prelude2::*,
|
||||||
RequestError,
|
RequestError,
|
||||||
};
|
};
|
||||||
use thiserror::Error;
|
use thiserror::Error;
|
||||||
|
|
|
@ -49,7 +49,6 @@ pub mod dialogue;
|
||||||
pub mod stop_token;
|
pub mod stop_token;
|
||||||
pub mod update_listeners;
|
pub mod update_listeners;
|
||||||
|
|
||||||
#[cfg(feature = "old-dispatching")]
|
|
||||||
pub(crate) mod repls;
|
pub(crate) mod repls;
|
||||||
|
|
||||||
mod dispatcher;
|
mod dispatcher;
|
||||||
|
@ -63,7 +62,7 @@ pub use dispatcher_handler_rx_ext::DispatcherHandlerRxExt;
|
||||||
use tokio::sync::mpsc::UnboundedReceiver;
|
use tokio::sync::mpsc::UnboundedReceiver;
|
||||||
pub use update_with_cx::{UpdateWithCx, UpdateWithCxRequesterType};
|
pub use update_with_cx::{UpdateWithCx, UpdateWithCxRequesterType};
|
||||||
|
|
||||||
#[cfg(feature = "new-dispatching")]
|
#[cfg(feature = "dispatching2")]
|
||||||
pub(crate) use dispatcher::{
|
pub(crate) use dispatcher::{
|
||||||
shutdown_check_timeout_for, shutdown_inner, DispatcherState, ShutdownState,
|
shutdown_check_timeout_for, shutdown_inner, DispatcherState, ShutdownState,
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
pub(crate) mod repls;
|
pub mod repls;
|
||||||
|
|
||||||
pub mod dialogue;
|
pub mod dialogue;
|
||||||
mod dispatcher;
|
mod dispatcher;
|
||||||
|
|
20
src/lib.rs
20
src/lib.rs
|
@ -60,28 +60,26 @@
|
||||||
// https://github.com/rust-lang/rust-clippy/issues/7422
|
// https://github.com/rust-lang/rust-clippy/issues/7422
|
||||||
#![allow(clippy::nonstandard_macro_braces)]
|
#![allow(clippy::nonstandard_macro_braces)]
|
||||||
|
|
||||||
#[cfg(all(feature = "new-dispatching", feature = "old-dispatching"))]
|
|
||||||
compile_error!("You can use only one of еру dispatching systems, not both.");
|
|
||||||
|
|
||||||
#[cfg(feature = "old-dispatching")]
|
|
||||||
pub use dispatching::repls::{
|
pub use dispatching::repls::{
|
||||||
commands_repl, commands_repl_with_listener, dialogues_repl, dialogues_repl_with_listener, repl,
|
commands_repl, commands_repl_with_listener, dialogues_repl, dialogues_repl_with_listener, repl,
|
||||||
repl_with_listener,
|
repl_with_listener,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[cfg(feature = "new-dispatching")]
|
#[cfg(feature = "dispatching2")]
|
||||||
pub use dispatching2::repls::{
|
pub use dispatching2::repls as repls2;
|
||||||
commands_repl, commands_repl_with_listener, repl, repl_with_listener,
|
|
||||||
};
|
|
||||||
|
|
||||||
mod logging;
|
mod logging;
|
||||||
|
|
||||||
// Things from this module is also used for the dispatching2 module.
|
// Things from this module is also used for the dispatching2 module.
|
||||||
pub mod dispatching;
|
pub mod dispatching;
|
||||||
#[cfg(feature = "new-dispatching")]
|
#[cfg(feature = "dispatching2")]
|
||||||
|
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "dispatching2")))]
|
||||||
pub mod dispatching2;
|
pub mod dispatching2;
|
||||||
pub mod error_handlers;
|
pub mod error_handlers;
|
||||||
pub mod prelude;
|
pub mod prelude;
|
||||||
|
#[cfg(feature = "dispatching2")]
|
||||||
|
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "dispatching2")))]
|
||||||
|
pub mod prelude2;
|
||||||
pub mod utils;
|
pub mod utils;
|
||||||
|
|
||||||
#[doc(inline)]
|
#[doc(inline)]
|
||||||
|
@ -91,8 +89,8 @@ pub use teloxide_core::*;
|
||||||
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "macros")))]
|
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "macros")))]
|
||||||
pub use teloxide_macros as macros;
|
pub use teloxide_macros as macros;
|
||||||
|
|
||||||
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "new-dispatching")))]
|
#[cfg(feature = "dispatching2")]
|
||||||
#[cfg(feature = "new-dispatching")]
|
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "dispatching2")))]
|
||||||
pub use dptree;
|
pub use dptree;
|
||||||
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "macros")))]
|
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "macros")))]
|
||||||
#[cfg(feature = "macros")]
|
#[cfg(feature = "macros")]
|
||||||
|
|
|
@ -5,7 +5,6 @@ pub use crate::{
|
||||||
respond,
|
respond,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[cfg(feature = "old-dispatching")]
|
|
||||||
pub use crate::dispatching::{
|
pub use crate::dispatching::{
|
||||||
dialogue::{
|
dialogue::{
|
||||||
exit, next, DialogueDispatcher, DialogueStage, DialogueWithCx, GetChatId, Transition,
|
exit, next, DialogueDispatcher, DialogueStage, DialogueWithCx, GetChatId, Transition,
|
||||||
|
@ -14,12 +13,6 @@ pub use crate::dispatching::{
|
||||||
Dispatcher, DispatcherHandlerRx, DispatcherHandlerRxExt, UpdateWithCx,
|
Dispatcher, DispatcherHandlerRx, DispatcherHandlerRxExt, UpdateWithCx,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[cfg(feature = "new-dispatching")]
|
|
||||||
pub use crate::dispatching2::{
|
|
||||||
dialogue::{Dialogue, DialogueHandlerExt as _},
|
|
||||||
Dispatcher, HandlerExt as _,
|
|
||||||
};
|
|
||||||
|
|
||||||
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "macros")))]
|
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "macros")))]
|
||||||
#[cfg(feature = "macros")]
|
#[cfg(feature = "macros")]
|
||||||
pub use crate::teloxide;
|
pub use crate::teloxide;
|
||||||
|
@ -42,5 +35,3 @@ pub use crate::utils::UpState;
|
||||||
pub use tokio::sync::mpsc::UnboundedReceiver;
|
pub use tokio::sync::mpsc::UnboundedReceiver;
|
||||||
|
|
||||||
pub use futures::StreamExt;
|
pub use futures::StreamExt;
|
||||||
|
|
||||||
pub use dptree::{self, prelude::*};
|
|
||||||
|
|
28
src/prelude2.rs
Normal file
28
src/prelude2.rs
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
//! Commonly used items (dispatching2 version).
|
||||||
|
|
||||||
|
pub use crate::{
|
||||||
|
error_handlers::{LoggingErrorHandler, OnError},
|
||||||
|
respond,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub use crate::dispatching2::{
|
||||||
|
dialogue::{Dialogue, DialogueHandlerExt as _},
|
||||||
|
Dispatcher, HandlerExt as _,
|
||||||
|
};
|
||||||
|
|
||||||
|
#[cfg_attr(all(docsrs, feature = "nightly"), doc(cfg(feature = "macros")))]
|
||||||
|
#[cfg(feature = "macros")]
|
||||||
|
pub use crate::teloxide;
|
||||||
|
|
||||||
|
pub use teloxide_core::types::{
|
||||||
|
CallbackQuery, ChatMemberUpdated, ChosenInlineResult, InlineQuery, Message, Poll, PollAnswer,
|
||||||
|
PreCheckoutQuery, ShippingQuery,
|
||||||
|
};
|
||||||
|
|
||||||
|
#[cfg(feature = "auto-send")]
|
||||||
|
pub use crate::adaptors::AutoSend;
|
||||||
|
|
||||||
|
#[doc(no_inline)]
|
||||||
|
pub use teloxide_core::prelude::*;
|
||||||
|
|
||||||
|
pub use dptree::{self, prelude::*};
|
Loading…
Add table
Reference in a new issue