1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
// Copyright (c) Ankit Chaubey <ankitchaubey.dev@gmail.com>
//
// ferogram: async Telegram MTProto client in Rust
// https://github.com/ankit-chaubey/ferogram
//
// Licensed under either the MIT License or the Apache License 2.0.
// See the LICENSE-MIT or LICENSE-APACHE file in this repository:
// https://github.com/ankit-chaubey/ferogram
//
// Feel free to use, modify, and share this code.
// Please keep this notice when redistributing.
//! Configuration for user-facing update buffering.
//!
//! Internal MTProto state (pts, qts, gap detection, getDifference) always
//! runs inside the reader task and is never interrupted. Only the high-level
//! [`Update`] queue that your application reads from [`stream_updates()`]
//! is controlled by these types.
//!
//! [`Update`]: crate::update::Update
//! [`stream_updates()`]: crate::Client::stream_updates
/// What to do when the user-dispatch queue is at capacity and a new update arrives.
///
/// Regardless of which strategy is chosen, internal MTProto state (pts, qts,
/// gap detection) is always processed and never dropped.
/// Coarse priority used to decide which buffered update to evict first when
/// `OverflowStrategy::DropOldest` is active and the queue is full.
pub
/// Classify a high-level [`Update`] by eviction priority.
///
/// [`Update`]: crate::update::Update
pub
/// Configuration for the user-facing update dispatch queue.
///
/// Pass this via [`ClientBuilder::update_queue_capacity`] /
/// [`ClientBuilder::update_overflow_strategy`] or set
/// `Config::update_config` directly.
///
/// # Example
///
/// ```rust,no_run
/// use ferogram::{Client, update_config::{UpdateConfig, OverflowStrategy}};
///
/// # #[tokio::main] async fn main() -> anyhow::Result<()> {
/// let (client, _) = Client::builder()
/// .api_id(12345)
/// .api_hash("abc")
/// .session("bot.session")
/// .update_queue_capacity(512)
/// .update_overflow_strategy(OverflowStrategy::DropOldest)
/// .connect().await?;
/// # Ok(()) }
/// ```