X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/abb8cd6526f36e74ce4476e93aa588c03e78b11c..305d783c9c259a5ec28836bdf697f73c6451aa2f:/examples/cpp/comm-failure/s4u-comm-failure.cpp diff --git a/examples/cpp/comm-failure/s4u-comm-failure.cpp b/examples/cpp/comm-failure/s4u-comm-failure.cpp index c278faca08..33c7729e00 100644 --- a/examples/cpp/comm-failure/s4u-comm-failure.cpp +++ b/examples/cpp/comm-failure/s4u-comm-failure.cpp @@ -24,8 +24,8 @@ public: void operator()() const { - auto mailbox1 = sg4::Mailbox::by_name(mailbox1_name); - auto mailbox2 = sg4::Mailbox::by_name(mailbox2_name); + auto* mailbox1 = sg4::Mailbox::by_name(mailbox1_name); + auto* mailbox2 = sg4::Mailbox::by_name(mailbox2_name); XBT_INFO("Initiating asynchronous send to %s", mailbox1->get_cname()); auto comm1 = mailbox1->put_async((void*)666, 5); @@ -33,12 +33,12 @@ public: auto comm2 = mailbox2->put_async((void*)666, 2); XBT_INFO("Calling wait_any.."); - std::vector pending_comms; - pending_comms.push_back(comm1); - pending_comms.push_back(comm2); + sg4::ActivitySet pending_comms; + pending_comms.push(comm1); + pending_comms.push(comm2); try { - long index = sg4::Comm::wait_any(pending_comms); - XBT_INFO("Wait any returned index %ld (comm to %s)", index, pending_comms.at(index)->get_mailbox()->get_cname()); + auto* acti = pending_comms.wait_any().get(); + XBT_INFO("Wait any returned comm to %s", dynamic_cast(acti)->get_mailbox()->get_cname()); } catch (const simgrid::NetworkFailureException&) { XBT_INFO("Sender has experienced a network failure exception, so it knows that something went wrong"); XBT_INFO("Now it needs to figure out which of the two comms failed by looking at their state:"); @@ -52,8 +52,7 @@ public: XBT_INFO("Waiting on a FAILED comm raises an exception: '%s'", e.what()); } XBT_INFO("Wait for remaining comm, just to be nice"); - pending_comms.erase(pending_comms.begin()); - sg4::Comm::wait_any(pending_comms); + pending_comms.wait_all(); } }; @@ -82,18 +81,17 @@ int main(int argc, char** argv) auto* host1 = zone->create_host("Host1", "1f"); auto* host2 = zone->create_host("Host2", "1f"); auto* host3 = zone->create_host("Host3", "1f"); + auto* link2 = zone->create_link("linkto2", "1bps")->seal(); + auto* link3 = zone->create_link("linkto3", "1bps")->seal(); - sg4::LinkInRoute linkto2{zone->create_link("linkto2", "1bps")->seal()}; - sg4::LinkInRoute linkto3{zone->create_link("linkto3", "1bps")->seal()}; - - zone->add_route(host1->get_netpoint(), host2->get_netpoint(), nullptr, nullptr, {linkto2}, false); - zone->add_route(host1->get_netpoint(), host3->get_netpoint(), nullptr, nullptr, {linkto3}, false); + zone->add_route(host1, host2, {link2}); + zone->add_route(host1, host3, {link3}); zone->seal(); sg4::Actor::create("Sender", host1, Sender("mailbox2", "mailbox3")); sg4::Actor::create("Receiver", host2, Receiver("mailbox2")); sg4::Actor::create("Receiver", host3, Receiver("mailbox3")); - + sg4::Actor::create("LinkKiller", host1, [](){ sg4::this_actor::sleep_for(10.0); XBT_INFO("Turning off link 'linkto2'");