pub_sub.cpp 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. //
  2. // Copyright (c) 2019-2020 Ivan Baidakou (basiliscos) (the dot dmol at gmail dot com)
  3. //
  4. // Distributed under the MIT Software License
  5. //
  6. #include "rotor.hpp"
  7. #include <iostream>
  8. namespace r = rotor;
  9. struct payload_t {};
  10. using sample_message_t = r::message_t<payload_t>;
  11. struct pub_t : public r::actor_base_t {
  12. using r::actor_base_t::actor_base_t;
  13. void set_pub_addr(const r::address_ptr_t &addr) { pub_addr = addr; }
  14. void on_start() noexcept override {
  15. r::actor_base_t::on_start();
  16. send<payload_t>(pub_addr);
  17. }
  18. r::address_ptr_t pub_addr;
  19. };
  20. struct sub_t : public r::actor_base_t {
  21. using r::actor_base_t::actor_base_t;
  22. void set_pub_addr(const r::address_ptr_t &addr) { pub_addr = addr; }
  23. void configure(r::plugin::plugin_base_t &plugin) noexcept override {
  24. rotor::actor_base_t::configure(plugin);
  25. plugin.with_casted<r::plugin::starter_plugin_t>(
  26. [&](auto &p) { p.subscribe_actor(&sub_t::on_payload, pub_addr); });
  27. }
  28. void on_payload(sample_message_t &) noexcept { std::cout << "received on " << static_cast<void *>(this) << "\n"; }
  29. r::address_ptr_t pub_addr;
  30. };
  31. struct dummy_supervisor : public rotor::supervisor_t {
  32. using rotor::supervisor_t::supervisor_t;
  33. void do_start_timer(const rotor::pt::time_duration &, rotor::timer_handler_base_t &) noexcept override {}
  34. void do_cancel_timer(rotor::request_id_t) noexcept override {}
  35. void start() noexcept override {}
  36. void shutdown() noexcept override {}
  37. void enqueue(rotor::message_ptr_t) noexcept override {}
  38. };
  39. int main() {
  40. rotor::system_context_t ctx{};
  41. auto timeout = boost::posix_time::milliseconds{500}; /* does not matter */
  42. auto sup = ctx.create_supervisor<dummy_supervisor>().timeout(timeout).finish();
  43. auto pub_addr = sup->create_address(); // (1)
  44. auto pub = sup->create_actor<pub_t>().timeout(timeout).finish();
  45. auto sub1 = sup->create_actor<sub_t>().timeout(timeout).finish();
  46. auto sub2 = sup->create_actor<sub_t>().timeout(timeout).finish();
  47. pub->set_pub_addr(pub_addr);
  48. sub1->set_pub_addr(pub_addr);
  49. sub2->set_pub_addr(pub_addr);
  50. sup->do_process();
  51. sup->do_shutdown();
  52. sup->do_process();
  53. return 0;
  54. }