A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Revert "Revert "actually fix the memleak around smpi's process_data" and "try to...
[simgrid.git]
/
src
/
smpi
/
internals
/
smpi_global.cpp
diff --git
a/src/smpi/internals/smpi_global.cpp
b/src/smpi/internals/smpi_global.cpp
index
5b0bab3
..
091dcb2
100644
(file)
--- a/
src/smpi/internals/smpi_global.cpp
+++ b/
src/smpi/internals/smpi_global.cpp
@@
-623,6
+623,13
@@
void SMPI_init(){
simgrid::s4u::Actor::onCreation.connect([](simgrid::s4u::ActorPtr actor) {
process_data.insert({actor, new simgrid::smpi::Process(actor, nullptr)});
});
simgrid::s4u::Actor::onCreation.connect([](simgrid::s4u::ActorPtr actor) {
process_data.insert({actor, new simgrid::smpi::Process(actor, nullptr)});
});
+ simgrid::s4u::Actor::onDestruction.connect([](simgrid::s4u::ActorPtr actor) {
+ if (process_data.find(actor) != process_data.end()) {
+ delete process_data.at(actor);
+ process_data.erase(actor);
+ }
+ });
+
smpi_init_options();
smpi_global_init();
smpi_check_options();
smpi_init_options();
smpi_global_init();
smpi_check_options();