X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b8df87e176f27b25534f27d7e240defa32ca35bc..4e46fb705a7ae3d90e14ea3b9a0cc9b4e9007f99:/src/simix/smx_private.hpp diff --git a/src/simix/smx_private.hpp b/src/simix/smx_private.hpp index f22840caaf..ce23e8fde2 100644 --- a/src/simix/smx_private.hpp +++ b/src/simix/smx_private.hpp @@ -24,16 +24,24 @@ class Global { friend XBT_PUBLIC bool simgrid::s4u::this_actor::is_maestro(); public: + /** + * Garbage collection + * + * Should be called some time to time to free the memory allocated for actors that have finished (or killed). + */ + void empty_trash(); + void run_all_actors(); + smx_context_factory_t context_factory = nullptr; - std::vector process_to_run; - std::vector process_that_ran; + std::vector actors_to_run; + std::vector actors_that_ran; std::map process_list; boost::intrusive::list, &kernel::actor::ActorImpl::smx_destroy_list_hook>> - process_to_destroy; + actors_to_destroy; #if SIMGRID_HAVE_MC - /* MCer cannot read members process_list and process_to_destroy above in the remote process, so we copy the info it + /* MCer cannot read members process_list and actors_to_destroy above in the remote process, so we copy the info it * needs in a dynar. * FIXME: This is supposed to be a temporary hack. * A better solution would be to change the split between MCer and MCed, where the responsibility @@ -72,9 +80,9 @@ XBT_PUBLIC void SIMIX_clean(); if (1) { \ simgrid::kernel::actor::ActorImpl* _smx_throw_issuer = (issuer); /* evaluate only once */ \ xbt_ex e(XBT_THROW_POINT, msg); \ - e.category = cat; \ - e.value = val; \ - _smx_throw_issuer->exception = std::make_exception_ptr(e); \ + e.category = cat; \ + e.value = val; \ + _smx_throw_issuer->exception_ = std::make_exception_ptr(e); \ } else \ ((void)0)