1 /* Copyright (c) 2019-2021. The SimGrid Team. All rights reserved. */
3 /* This program is free software; you can redistribute it and/or modify it
4 * under the terms of the license (GNU LGPL) which comes with this package. */
9 #include <simgrid/s4u.hpp>
11 XBT_LOG_NEW_DEFAULT_CATEGORY(meh, "meh");
15 auto mbox = simgrid::s4u::Mailbox::by_name("meh");
19 XBT_INFO("Sending and receiving %d and %d asynchronously", input1, input2);
21 auto put1 = mbox->put_async(&input1, 1000 * 1000 * 500);
22 auto put2 = mbox->put_async(&input2, 1000 * 1000 * 1000);
25 auto get1 = mbox->get_async<int>(&out1);
28 auto get2 = mbox->get_async<int>(&out2);
30 XBT_INFO("All comms have started");
31 std::vector<simgrid::s4u::CommPtr> comms = {put1, put2, get1, get2};
33 while (not comms.empty()) {
34 ssize_t index = simgrid::s4u::Comm::wait_any_for(comms, 0.5);
36 XBT_INFO("wait_any_for: Timeout reached");
38 XBT_INFO("wait_any_for: A comm finished (index=%zd, #comms=%zu)", index, comms.size());
39 comms.erase(comms.begin() + index);
43 XBT_INFO("All comms have finished");
44 XBT_INFO("Got %d and %d", *out1, *out2);
47 int main(int argc, char* argv[])
50 simgrid::s4u::Engine e(&argc, argv);
51 e.load_platform(argv[1]);
52 simgrid::s4u::Actor::create("worker", simgrid::s4u::Host::by_name("Tremblay"), worker);