Improve Event logging.

GitOrigin-RevId: 67a3e5f82f972b4d6b40e07215a28b6edea005c3
This commit is contained in:
levlam 2020-07-19 20:15:06 +03:00
parent 8efb30d34f
commit 340c98772d
3 changed files with 32 additions and 29 deletions

View File

@ -242,8 +242,27 @@ class Event {
} }
}; };
inline StringBuilder &operator<<(StringBuilder &sb, const Event &e) { inline StringBuilder &operator<<(StringBuilder &string_builder, const Event &e) {
return sb << tag("Event", static_cast<int32>(e.type)); string_builder << "Event::";
switch (e.type) {
case Event::Type::Start:
return string_builder << "Start";
case Event::Type::Stop:
return string_builder << "Stop";
case Event::Type::Yield:
return string_builder << "Yield";
case Event::Type::Hangup:
return string_builder << "Hangup";
case Event::Type::Timeout:
return string_builder << "Timeout";
case Event::Type::Raw:
return string_builder << "Raw";
case Event::Type::Custom:
return string_builder << "Custom";
case Event::Type::NoType:
default:
return string_builder << "NoType";
}
} }
} // namespace td } // namespace td

View File

@ -253,52 +253,37 @@ void Scheduler::clear() {
void Scheduler::do_event(ActorInfo *actor_info, Event &&event) { void Scheduler::do_event(ActorInfo *actor_info, Event &&event) {
event_context_ptr_->link_token = event.link_token; event_context_ptr_->link_token = event.link_token;
auto actor = actor_info->get_actor_unsafe(); auto actor = actor_info->get_actor_unsafe();
VLOG(actor) << *actor_info << ' ' << event;
switch (event.type) { switch (event.type) {
case Event::Type::Start: { case Event::Type::Start:
VLOG(actor) << *actor_info << " Event::Start";
actor->start_up(); actor->start_up();
break; break;
} case Event::Type::Stop:
case Event::Type::Stop: {
VLOG(actor) << *actor_info << " Event::Stop";
actor->tear_down(); actor->tear_down();
break; break;
} case Event::Type::Yield:
case Event::Type::Yield: {
VLOG(actor) << *actor_info << " Event::Yield";
actor->wakeup(); actor->wakeup();
break; break;
} case Event::Type::Hangup:
case Event::Type::Hangup: { if (get_link_token(actor) != 0) {
auto token = get_link_token(actor);
VLOG(actor) << *actor_info << " Event::Hangup " << tag("token", format::as_hex(token));
if (token != 0) {
actor->hangup_shared(); actor->hangup_shared();
} else { } else {
actor->hangup(); actor->hangup();
} }
break; break;
} case Event::Type::Timeout:
case Event::Type::Timeout: {
VLOG(actor) << *actor_info << " Event::Timeout";
actor->timeout_expired(); actor->timeout_expired();
break; break;
} case Event::Type::Raw:
case Event::Type::Raw: {
VLOG(actor) << *actor_info << " Event::Raw";
actor->raw_event(event.data); actor->raw_event(event.data);
break; break;
} case Event::Type::Custom:
case Event::Type::Custom: {
do_custom_event(actor_info, *event.data.custom_event); do_custom_event(actor_info, *event.data.custom_event);
break; break;
} case Event::Type::NoType:
case Event::Type::NoType: {
UNREACHABLE();
break;
}
default: default:
UNREACHABLE(); UNREACHABLE();
break;
} }
// can't clear event here. It may be already destroyed during destory_actor // can't clear event here. It may be already destroyed during destory_actor
} }

View File

@ -152,7 +152,6 @@ inline void Scheduler::destroy_actor(ActorInfo *actor_info) {
} }
inline void Scheduler::do_custom_event(ActorInfo *actor_info, CustomEvent &event) { inline void Scheduler::do_custom_event(ActorInfo *actor_info, CustomEvent &event) {
VLOG(actor) << *actor_info << " Event::Custom";
event.run(actor_info->get_actor_unsafe()); event.run(actor_info->get_actor_unsafe());
} }