X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/85c342932c60954a7e1c9430742bfff2b28c31a8..c91b68ade95e42efb7a24f19fb5228bee0b618d0:/tools/gras/stub_generator.c diff --git a/tools/gras/stub_generator.c b/tools/gras/stub_generator.c index 5de317aa19..3d32883591 100644 --- a/tools/gras/stub_generator.c +++ b/tools/gras/stub_generator.c @@ -21,6 +21,7 @@ #include "gras_stub_generator.h" #include +XBT_PUBLIC(char*)xbt_binary_name; XBT_LOG_NEW_DEFAULT_SUBCATEGORY(stubgen, gras, "Stub generator"); @@ -45,49 +46,21 @@ char *warning = NULL; void s_process_free(void *process) { s_process_t *p = (s_process_t *) process; - int i; - for (i = 0; i < p->argc; i++) - free(p->argv[i]); - free(p->argv); free(p->host); } static s_process_t process; -static void parse_process_init(void) +static void parse_process(sg_platf_process_cbarg_t process_arg) { - xbt_dict_set(process_function_set, A_surfxml_process_function, NULL, - NULL); - xbt_dict_set(machine_set, A_surfxml_process_host, NULL, NULL); - process.argc = 1; - process.argv = xbt_new(char *, 1); - process.argv[0] = xbt_strdup(A_surfxml_process_function); - process.host = strdup(A_surfxml_process_host); + xbt_dict_set(process_function_set, process_arg->function, NULL, NULL); + xbt_dict_set(machine_set, process_arg->host, NULL, NULL); + process.argc = process_arg->argc; + process.argv = (char**)(process_arg->argv); + process.host = strdup(process_arg->host); /*XBT_VERB("Function: %s",A_surfxml_process_function); */ -} - -static void parse_argument(void) -{ - process.argc++; - process.argv = - xbt_realloc(process.argv, (process.argc) * sizeof(char *)); - process.argv[(process.argc) - 1] = xbt_strdup(A_surfxml_argument_value); -} - -static void parse_process_finalize(void) -{ xbt_dynar_push(process_list, &process); - /*XBT_VERB("Function: %s",process.argv[0]); */ -} - -/*FIXME Defined in surfxml_parse.c*/ -#ifndef WIN32 -void surfxml_add_callback(xbt_dynar_t cb_list, void_f_void_t function) -{ - xbt_dynar_push(cb_list, &function); } -#endif - int main(int argc, char *argv[]) { @@ -95,10 +68,14 @@ int main(int argc, char *argv[]) char *deployment_file = NULL; int i; + XBT_LOG_CONNECT(stubgen); + + xbt_binary_name=xbt_strdup(argv[0]); + surf_init(&argc, argv); - process_function_set = xbt_dict_new(); + process_function_set = xbt_dict_new_homogeneous(NULL); process_list = xbt_dynar_new(sizeof(s_process_t), s_process_free); - machine_set = xbt_dict_new(); + machine_set = xbt_dict_new_homogeneous(NULL); for (i = 1; i < argc; i++) { int need_removal = 0; @@ -127,11 +104,7 @@ int main(int argc, char *argv[]) project_name = argv[1]; surf_parse_reset_callbacks(); - XBT_DEBUG("%p %p", parse_process_init, &parse_process_init); - surfxml_add_callback(STag_surfxml_process_cb_list, &parse_process_init); - surfxml_add_callback(ETag_surfxml_argument_cb_list, &parse_argument); - surfxml_add_callback(ETag_surfxml_process_cb_list, - &parse_process_finalize); + sg_platf_process_add_cb(parse_process); for (i = 2; i < argc; i++) { deployment_file = argv[i]; @@ -174,6 +147,9 @@ int main(int argc, char *argv[]) free(warning); + + xbt_free(process.argv); + xbt_dict_free(&process_function_set); xbt_dynar_free(&process_list); xbt_dict_free(&machine_set);