pub_sub.cpp 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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 "dummy_supervisor.h"
  8. #include <iostream>
  9. namespace r = rotor;
  10. struct payload_t {};
  11. using sample_message_t = r::message_t<payload_t>;
  12. struct pub_t : public r::actor_base_t {
  13. using r::actor_base_t::actor_base_t;
  14. void set_pub_addr(const r::address_ptr_t &addr) { pub_addr = addr; }
  15. void on_start() noexcept override {
  16. r::actor_base_t::on_start();
  17. send<payload_t>(pub_addr);
  18. }
  19. r::address_ptr_t pub_addr;
  20. };
  21. struct sub_t : public r::actor_base_t {
  22. using r::actor_base_t::actor_base_t;
  23. void set_pub_addr(const r::address_ptr_t &addr) { pub_addr = addr; }
  24. void configure(r::plugin::plugin_base_t &plugin) noexcept override {
  25. rotor::actor_base_t::configure(plugin);
  26. plugin.with_casted<r::plugin::starter_plugin_t>(
  27. [&](auto &p) { p.subscribe_actor(&sub_t::on_payload, pub_addr); });
  28. }
  29. void on_payload(sample_message_t &) noexcept { std::cout << "received on " << static_cast<void *>(this) << "\n"; }
  30. r::address_ptr_t pub_addr;
  31. };
  32. int main() {
  33. rotor::system_context_t ctx{};
  34. auto timeout = boost::posix_time::milliseconds{500}; /* does not matter */
  35. auto sup = ctx.create_supervisor<dummy_supervisor_t>().timeout(timeout).finish();
  36. auto pub_addr = sup->create_address(); // (1)
  37. auto pub = sup->create_actor<pub_t>().timeout(timeout).finish();
  38. auto sub1 = sup->create_actor<sub_t>().timeout(timeout).finish();
  39. auto sub2 = sup->create_actor<sub_t>().timeout(timeout).finish();
  40. pub->set_pub_addr(pub_addr);
  41. sub1->set_pub_addr(pub_addr);
  42. sub2->set_pub_addr(pub_addr);
  43. sup->do_process();
  44. sup->do_shutdown();
  45. sup->do_process();
  46. return 0;
  47. }