m.attr("simgrid_version") = simgrid_version;
// Internal exception used to kill actors and sweep the RAII chimney (free objects living on the stack)
- py::object pyStopRequestEx = py::register_exception<simgrid::kernel::context::StopRequest>(m, "ActorKilled");
+ py::object pyForcefulKillEx =
+ py::register_exception<simgrid::kernel::context::ForcefulKillException>(m, "ActorKilled");
/* this_actor namespace */
void (*sleep_for_fun)(double) = &simgrid::s4u::this_actor::sleep_for; // pick the right overload
":cpp:func:`simgrid::s4u::Engine::load_deployment()`")
.def("run", &Engine::run, "Run the simulation")
.def("register_actor",
- [pyStopRequestEx](Engine*, std::string name, py::object fun_or_class) {
+ [pyForcefulKillEx](Engine*, const std::string& name, py::object fun_or_class) {
simgrid::simix::register_function(
- name, [pyStopRequestEx, fun_or_class](std::vector<std::string> args) -> simgrid::simix::ActorCode {
- return [pyStopRequestEx, fun_or_class, args]() {
+ name, [pyForcefulKillEx, fun_or_class](std::vector<std::string> args) -> simgrid::simix::ActorCode {
+ return [pyForcefulKillEx, fun_or_class, args]() {
try {
/* Convert the std::vector into a py::tuple */
py::tuple params(args.size() - 1);
if (py::isinstance<py::function>(res))
res();
} catch (py::error_already_set& ex) {
- if (ex.matches(pyStopRequestEx)) {
+ if (ex.matches(pyForcefulKillEx)) {
XBT_VERB("Actor killed");
- /* Stop here that StopRequest exception which was meant to free the RAII stuff on the stack */
+ /* Stop here that ForcefulKill exception which was meant to free the RAII stuff on the stack */
} else {
throw;
}
"application, see :ref:`class s4u::Actor <API_s4u_Actor>`")
.def("create",
- [pyStopRequestEx](py::str name, py::object host, py::object fun, py::args args) {
+ [pyForcefulKillEx](py::str name, py::object host, py::object fun, py::args args) {
- return simgrid::s4u::Actor::create(name, host.cast<Host*>(), [fun, args, pyStopRequestEx]() {
+ return simgrid::s4u::Actor::create(name, host.cast<Host*>(), [fun, args, pyForcefulKillEx]() {
try {
fun(*args);
} catch (py::error_already_set& ex) {
- if (ex.matches(pyStopRequestEx)) {
+ if (ex.matches(pyForcefulKillEx)) {
XBT_VERB("Actor killed");
- /* Stop here that StopRequest exception which was meant to free the RAII stuff on the stack */
+ /* Stop here that ForcefulKill exception which was meant to free the RAII stuff on the stack */
} else {
throw;
}