1 /* Copyright (c) 2023-. 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. */
6 #include "src/kernel/activity/ActivityImpl.hpp"
7 #include "src/kernel/actor/ActorImpl.hpp"
8 #include "src/kernel/actor/CommObserver.hpp"
9 #include <simgrid/s4u/ActivitySet.hpp>
10 #include <simgrid/s4u/Engine.hpp>
12 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(s4u_activityset, s4u_activity, "S4U set of activities");
14 namespace simgrid::s4u {
16 void ActivitySet::erase(ActivityPtr a)
18 for (auto it = activities_.begin(); it != activities_.end(); it++)
20 activities_.erase(it);
25 void ActivitySet::wait_all_for(double timeout)
28 for (const auto& act : activities_)
33 double deadline = Engine::get_clock() + timeout;
34 for (const auto& act : activities_)
35 act->wait_until(deadline);
39 ActivityPtr ActivitySet::test_any()
41 std::vector<kernel::activity::ActivityImpl*> act_impls(activities_.size());
42 std::transform(begin(activities_), end(activities_), begin(act_impls),
43 [](const ActivityPtr& act) { return act->pimpl_.get(); });
45 kernel::actor::ActorImpl* issuer = kernel::actor::ActorImpl::self();
46 kernel::actor::ActivityTestanySimcall observer{issuer, act_impls, "test_any"};
47 ssize_t changed_pos = kernel::actor::simcall_answered(
49 return kernel::activity::ActivityImpl::test_any(observer.get_issuer(), observer.get_activities());
52 if (changed_pos == -1)
53 return ActivityPtr(nullptr);
55 auto ret = activities_.at(changed_pos);
57 ret->complete(Activity::State::FINISHED);
61 ActivityPtr ActivitySet::wait_any_for(double timeout)
63 std::vector<kernel::activity::ActivityImpl*> act_impls(activities_.size());
64 std::transform(begin(activities_), end(activities_), begin(act_impls),
65 [](const ActivityPtr& activity) { return activity->pimpl_.get(); });
67 kernel::actor::ActorImpl* issuer = kernel::actor::ActorImpl::self();
68 kernel::actor::ActivityWaitanySimcall observer{issuer, act_impls, timeout, "wait_any_for"};
69 ssize_t changed_pos = kernel::actor::simcall_blocking(
71 kernel::activity::ActivityImpl::wait_any_for(observer.get_issuer(), observer.get_activities(),
72 observer.get_timeout());
75 xbt_assert(changed_pos != -1,
76 "ActivityImpl::wait_any_for is not supposed to return -1 but instead to raise exceptions");
78 auto ret = activities_.at(changed_pos);
80 ret->complete(Activity::State::FINISHED);
84 ActivityPtr ActivitySet::get_failed_activity()
86 if (failed_activities_.empty())
87 return ActivityPtr(nullptr);
88 auto ret = failed_activities_.back();
89 failed_activities_.pop_back();
93 }; // namespace simgrid::s4u