From: Gabriel Corona Date: Thu, 16 Jun 2016 08:57:39 +0000 (+0200) Subject: [simix] Group simcall_process_create() X-Git-Tag: v3_14~985^2 X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/commitdiff_plain/fec4a65acf99dbd55e2f22c8f860abe642bfbd0f [simix] Group simcall_process_create() --- diff --git a/src/simix/libsmx.cpp b/src/simix/libsmx.cpp index 8e07b0c500..e7317084f5 100644 --- a/src/simix/libsmx.cpp +++ b/src/simix/libsmx.cpp @@ -351,44 +351,6 @@ void simcall_vm_migratefrom_resumeto(sg_host_t vm, sg_host_t src_pm, sg_host_t d SIMIX_vm_migratefrom_resumeto, vm, src_pm, dst_pm)); } -/** - * \ingroup simix_process_management - * \brief Creates and runs a new SIMIX process. - * - * The structure and the corresponding thread are created and put in the list of ready processes. - * - * \param name a name for the process. It is for user-level information and can be nullptr. - * \param code the main function of the process - * \param data a pointer to any data one may want to attach to the new object. It is for user-level information and can be nullptr. - * It can be retrieved with the function \ref simcall_process_get_data. - * \param hostname name of the host where the new agent is executed. - * \param kill_time time when the process is killed - * \param argc first argument passed to \a code - * \param argv second argument passed to \a code - * \param properties the properties of the process - * \param auto_restart either it is autorestarting or not. - */ -smx_process_t simcall_process_create(const char *name, - xbt_main_func_t code, - void *data, - const char *hostname, - double kill_time, - int argc, char **argv, - xbt_dict_t properties, - int auto_restart) -{ - if (name == nullptr) - name = ""; - auto wrapped_code = simgrid::xbt::wrapMain(code, argc, argv); - for (int i = 0; i != argc; ++i) - xbt_free(argv[i]); - xbt_free(argv); - smx_process_t res = simcall_process_create(name, - std::move(wrapped_code), - data, hostname, kill_time, properties, auto_restart); - return res; -} - /** * \ingroup simix_process_management * \brief Kills a SIMIX process. diff --git a/src/simix/smx_process.cpp b/src/simix/smx_process.cpp index bcd0600d2d..d7654ef19a 100644 --- a/src/simix/smx_process.cpp +++ b/src/simix/smx_process.cpp @@ -6,6 +6,8 @@ #include +#include + #include "src/surf/surf_interface.hpp" #include "smx_private.h" #include "xbt/sysdep.h" @@ -993,6 +995,44 @@ void SIMIX_segment_index_set(smx_process_t proc, int index){ proc->segment_index = index; } +/** + * \ingroup simix_process_management + * \brief Creates and runs a new SIMIX process. + * + * The structure and the corresponding thread are created and put in the list of ready processes. + * + * \param name a name for the process. It is for user-level information and can be nullptr. + * \param code the main function of the process + * \param data a pointer to any data one may want to attach to the new object. It is for user-level information and can be nullptr. + * It can be retrieved with the function \ref simcall_process_get_data. + * \param hostname name of the host where the new agent is executed. + * \param kill_time time when the process is killed + * \param argc first argument passed to \a code + * \param argv second argument passed to \a code + * \param properties the properties of the process + * \param auto_restart either it is autorestarting or not. + */ +smx_process_t simcall_process_create(const char *name, + xbt_main_func_t code, + void *data, + const char *hostname, + double kill_time, + int argc, char **argv, + xbt_dict_t properties, + int auto_restart) +{ + if (name == nullptr) + name = ""; + auto wrapped_code = simgrid::xbt::wrapMain(code, argc, argv); + for (int i = 0; i != argc; ++i) + xbt_free(argv[i]); + xbt_free(argv); + smx_process_t res = simcall_process_create(name, + std::move(wrapped_code), + data, hostname, kill_time, properties, auto_restart); + return res; +} + smx_process_t simcall_process_create( const char *name, std::function code, void *data, const char *hostname, double kill_time, @@ -1007,4 +1047,4 @@ smx_process_t simcall_process_create( kill_time, properties, auto_restart, self); }); -} \ No newline at end of file +}