Always wait for mailbox.

This commit is contained in:
levlam 2023-01-11 01:08:22 +03:00
parent 64406035a7
commit 3b6874818a
7 changed files with 1 additions and 18 deletions

View File

@ -13601,8 +13601,6 @@ void MessagesManager::init() {
td_->notification_settings_manager_->init(); // load scope notification settings td_->notification_settings_manager_->init(); // load scope notification settings
init_stickers_manager(td_); // load available reactions init_stickers_manager(td_); // load available reactions
always_wait_for_mailbox();
start_time_ = Time::now(); start_time_ = Time::now();
last_channel_pts_jump_warning_time_ = start_time_ - 3600; last_channel_pts_jump_warning_time_ = start_time_ - 3600;

View File

@ -3114,8 +3114,6 @@ void Td::on_connection_state_changed(ConnectionState new_state) {
} }
void Td::start_up() { void Td::start_up() {
always_wait_for_mailbox();
uint64 check_endianness = 0x0706050403020100; uint64 check_endianness = 0x0706050403020100;
auto check_endianness_raw = reinterpret_cast<const unsigned char *>(&check_endianness); auto check_endianness_raw = reinterpret_cast<const unsigned char *>(&check_endianness);
for (unsigned char c = 0; c < 8; c++) { for (unsigned char c = 0; c < 8; c++) {

View File

@ -79,8 +79,6 @@ class Actor : public ObserverBase {
std::shared_ptr<ActorContext> set_context(std::shared_ptr<ActorContext> context); std::shared_ptr<ActorContext> set_context(std::shared_ptr<ActorContext> context);
string set_tag(string tag); string set_tag(string tag);
void always_wait_for_mailbox();
// for ActorInfo mostly // for ActorInfo mostly
void init(ObjectPool<ActorInfo>::OwnerPtr &&info); void init(ObjectPool<ActorInfo>::OwnerPtr &&info);
ActorInfo *get_info(); ActorInfo *get_info();

View File

@ -164,8 +164,4 @@ inline Slice Actor::get_name() const {
return info_->get_name(); return info_->get_name();
} }
inline void Actor::always_wait_for_mailbox() {
info_->always_wait_for_mailbox();
}
} // namespace td } // namespace td

View File

@ -110,14 +110,12 @@ class ActorInfo final
void set_wait_generation(uint32 wait_generation); void set_wait_generation(uint32 wait_generation);
bool must_wait(uint32 wait_generation) const; bool must_wait(uint32 wait_generation) const;
void always_wait_for_mailbox();
private: private:
Deleter deleter_ = Deleter::None; Deleter deleter_ = Deleter::None;
bool need_context_ = true; bool need_context_ = true;
bool need_start_up_ = true; bool need_start_up_ = true;
bool is_running_ = false; bool is_running_ = false;
bool always_wait_for_mailbox_{false};
uint32 wait_generation_{0}; uint32 wait_generation_{0};
std::atomic<int32> sched_id_{0}; std::atomic<int32> sched_id_{0};

View File

@ -66,11 +66,7 @@ inline void ActorInfo::set_wait_generation(uint32 wait_generation) {
} }
inline bool ActorInfo::must_wait(uint32 wait_generation) const { inline bool ActorInfo::must_wait(uint32 wait_generation) const {
return wait_generation_ == wait_generation || (always_wait_for_mailbox_ && !mailbox_.empty()); return wait_generation_ == wait_generation || !mailbox_.empty();
}
inline void ActorInfo::always_wait_for_mailbox() {
always_wait_for_mailbox_ = true;
} }
inline void ActorInfo::on_actor_moved(Actor *actor_new_ptr) { inline void ActorInfo::on_actor_moved(Actor *actor_new_ptr) {

View File

@ -571,7 +571,6 @@ TEST(Actors, stop_in_teardown) {
class AlwaysWaitForMailbox final : public td::Actor { class AlwaysWaitForMailbox final : public td::Actor {
public: public:
void start_up() final { void start_up() final {
always_wait_for_mailbox();
td::create_actor<td::SleepActor>("Sleep", 0.1, td::create_actor<td::SleepActor>("Sleep", 0.1,
td::PromiseCreator::lambda([actor_id = actor_id(this), ptr = this](td::Unit) { td::PromiseCreator::lambda([actor_id = actor_id(this), ptr = this](td::Unit) {
td::send_closure(actor_id, &AlwaysWaitForMailbox::g); td::send_closure(actor_id, &AlwaysWaitForMailbox::g);