1
0
This repository has been archived on 2020-05-25. You can view files and clone it, but cannot push or open issues or pull requests.
levlam 5cbda834bd Update copyright year.
GitOrigin-RevId: 1369d3af1195221f6ddb9462d5f8b74fb5fef20f
2018-01-02 16:45:09 +03:00

50 lines
1.2 KiB
C++

//
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
#include "td/actor/actor.h"
#include "td/utils/logging.h"
class Worker : public td::Actor {
public:
void ping(int x) {
LOG(ERROR) << "got ping " << x;
}
};
class MainActor : public td::Actor {
public:
void start_up() override {
LOG(ERROR) << "start up";
set_timeout_in(10);
worker_ = td::create_actor_on_scheduler<Worker>("Worker", 1);
send_closure(worker_, &Worker::ping, 123);
}
void timeout_expired() override {
LOG(ERROR) << "timeout expired";
td::Scheduler::instance()->finish();
}
private:
td::ActorOwn<Worker> worker_;
};
int main(void) {
td::ConcurrentScheduler scheduler;
scheduler.init(4 /*threads_count*/);
scheduler.start();
{
auto guard = scheduler.get_current_guard();
td::create_actor_on_scheduler<MainActor>("Main actor", 0).release();
}
while (!scheduler.is_finished()) {
scheduler.run_main(10);
}
scheduler.finish();
return 0;
}