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
there is now a flush function
[simgrid.git]
/
src
/
xbt
/
module.c
diff --git
a/src/xbt/module.c
b/src/xbt/module.c
index
65638c8
..
4312035
100644
(file)
--- a/
src/xbt/module.c
+++ b/
src/xbt/module.c
@@
-13,6
+13,7
@@
GRAS_LOG_NEW_DEFAULT_SUBCATEGORY(module,GRAS);
extern void gras_log_exit(void);
GRAS_LOG_NEW_DEFAULT_SUBCATEGORY(module,GRAS);
extern void gras_log_exit(void);
+static int gras_running_process = 0;
struct gras_module_ {
gras_dynar_t *deps;
struct gras_module_ {
gras_dynar_t *deps;
@@
-23,7
+24,7
@@
struct gras_module_ {
};
void
};
void
-gras_init(int argc, char **argv) {
+gras_init(int
*
argc, char **argv) {
gras_init_defaultlog(argc, argv, NULL);
}
gras_init_defaultlog(argc, argv, NULL);
}
@@
-35,8
+36,8
@@
gras_init(int argc, char **argv) {
* Initialize the gras mecanisms.
*/
void
* Initialize the gras mecanisms.
*/
void
-gras_init_defaultlog(int argc,char **argv, const char *defaultlog) {
- int i;
+gras_init_defaultlog(int
*
argc,char **argv, const char *defaultlog) {
+ int i
,j
;
char *opt;
gras_error_t errcode;
int found=0;
char *opt;
gras_error_t errcode;
int found=0;
@@
-44,31
+45,49
@@
gras_init_defaultlog(int argc,char **argv, const char *defaultlog) {
INFO0("Initialize GRAS");
/** Set logs and init log submodule */
INFO0("Initialize GRAS");
/** Set logs and init log submodule */
- for (i=1; i<argc; i++) {
+ for (i=1; i<
*
argc; i++) {
if (!strncmp(argv[i],"--gras-log=",strlen("--gras-log="))) {
found = 1;
opt=strchr(argv[i],'=');
opt++;
TRYFAIL(gras_log_control_set(opt));
if (!strncmp(argv[i],"--gras-log=",strlen("--gras-log="))) {
found = 1;
opt=strchr(argv[i],'=');
opt++;
TRYFAIL(gras_log_control_set(opt));
+ DEBUG1("Did apply '%s' as log setting",opt);
+ /*remove this from argv*/
+ for (j=i+1; j<*argc; j++) {
+ argv[j-1] = argv[j];
+ }
+ argv[j-1] = NULL;
+ (*argc)--;
+ i--; /* compensate effect of next loop incrementation */
}
}
if (!found && defaultlog) {
TRYFAIL(gras_log_control_set(defaultlog));
}
}
}
if (!found && defaultlog) {
TRYFAIL(gras_log_control_set(defaultlog));
}
+ gras_process_init(); /* calls procdata_init, which calls dynar_new */
/** init other submodules */
/** init other submodules */
- gras_trp_init();
+ if (gras_running_process++ == 0) {
+ gras_msg_init();
+ gras_trp_init();
+ gras_datadesc_init();
+ }
}
/**
* gras_exit:
}
/**
* gras_exit:
- * @argc:
- * @argv:
*
* Finalize the gras mecanisms.
*/
void
gras_exit(){
*
* Finalize the gras mecanisms.
*/
void
gras_exit(){
- gras_trp_exit();
+ INFO0("Exiting GRAS");
+ gras_process_exit();
+ if (--gras_running_process == 0) {
+ gras_msg_exit();
+ gras_trp_exit();
+ gras_datadesc_exit();
+ }
gras_log_exit();
gras_log_exit();
+ DEBUG0("Exited GRAS");
}
}