X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/c01833fb710ae29445a4bbd6446abd12a293792b..bffbfb29b42b5cb1c3f70fd6a806f53e4412f78d:/src/smpi/internals/smpi_global.cpp diff --git a/src/smpi/internals/smpi_global.cpp b/src/smpi/internals/smpi_global.cpp index bd0b4e022a..e75aef976d 100644 --- a/src/smpi/internals/smpi_global.cpp +++ b/src/smpi/internals/smpi_global.cpp @@ -13,6 +13,7 @@ #include "src/smpi/include/smpi_actor.hpp" #include "xbt/config.hpp" +#include #include /* DBL_MAX */ #include #include @@ -426,14 +427,18 @@ typedef void (*smpi_fortran_entry_point_type)(); static int smpi_run_entry_point(smpi_entry_point_type entry_point, std::vector args) { - int argc_saved = args.size(); - int argc=argc_saved; - char** argv = new char*[argc + 1]; - for (int i = 0; i != argc; ++i) - argv[i] = xbt_strdup(args[i].c_str()); - argv[argc] = nullptr; - char* name = argv[0]; - char* instance = argv[1]; + // copy C strings, we need them writable + std::vector* args4argv = new std::vector(args.size()); + std::transform(begin(args), end(args), begin(*args4argv), [](const std::string& s) { return xbt_strdup(s.c_str()); }); + +#if !SMPI_IFORT + // take a copy of args4argv to keep reference of the allocated strings + const std::vector args2str(*args4argv); +#endif + int argc = args4argv->size(); + args4argv->push_back(nullptr); + char** argv = args4argv->data(); + simgrid::smpi::ActorExt::init(&argc, &argv); #if SMPI_IFORT for_rtl_init_ (&argc, argv); @@ -448,13 +453,9 @@ static int smpi_run_entry_point(smpi_entry_point_type entry_point, std::vector 3) { - xbt_free(instance); - xbt_free(name); - } - delete[] argv; + for (char* s : args2str) + xbt_free(s); + delete args4argv; #endif if (res != 0){