X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/1d8cb6f591df6a98552a9b5152bff4f66cec26ee..bffbfb29b42b5cb1c3f70fd6a806f53e4412f78d:/src/smpi/internals/smpi_global.cpp?ds=sidebyside diff --git a/src/smpi/internals/smpi_global.cpp b/src/smpi/internals/smpi_global.cpp index 9701a0ebd7..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,11 +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 = args.size(); - char** argv = new char*[argc + 1]; - for (int i = 0; i != argc; ++i) - argv[i] = xbt_strdup(args[i].c_str()); - argv[argc] = nullptr; + // 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); @@ -445,9 +453,9 @@ static int smpi_run_entry_point(smpi_entry_point_type entry_point, std::vector