#include #include #include #include #include #include #include void dp_nng_fatal(const std::string &msg, int rv) { spdlog::error("{}: {}", msg, nng_strerror(rv)); abort(); } void dp_errno_fatal(const std::string &msg) { spdlog::error("{}: {}", msg, strerror(errno)); abort(); } nng_socket make_ctrl_pub(const char *url) { nng_socket sock; if (auto res = nng_pub0_open(&sock)) dp_nng_fatal("make_ctrl_pub/nng_pub0_open", res); if (auto res = nng_listen(sock, url, nullptr, 0)) dp_nng_fatal("make_ctrl_pub/nng_listen", res); return sock; } nng_socket make_ctrl_sub(const char *url) { nng_socket sock; if (auto res = nng_sub0_open(&sock)) dp_nng_fatal("make_ctrl_pub/nng_sub0_open", res); if (auto res = nng_listen(sock, url, nullptr, 0)) dp_nng_fatal("make_ctrl_sub/nng_listen", res); return sock; } nng_socket make_doom_pub(const char *url) { } nng_socket make_doom_sub(const char *url) { } static const char *CtrlUrl = "ipc://666_ctrl.socket"; static const char *DoomUrl = "ipc://666_doom.socket"; static const size_t NumDooms = 2; int run_doom(size_t id) { spdlog::debug("doom#{} running", id); return 0; } int main(int argc, char *argv[]) { spdlog::set_level(spdlog::level::debug); spdlog::set_pattern("[%H:%M:%S.%e] [pid=%P] [%^%l%$] %v"); spdlog::info("Hello, doomed world!"); for (size_t i=0; i