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;
argv[j-1] = NULL;
(*argc)--;
i--; /* compensate effect of next loop incrementation */
- WARN1("argc %d",*argc);
}
}
if (!found && defaultlog) {
TRYFAIL(gras_log_control_set(defaultlog));
}
+ gras_process_init(); /* calls procdata_init, which calls dynar_new */
/** init other submodules */
- gras_msg_init();
- gras_trp_init();
- gras_datadesc_init();
+ if (gras_running_process++ == 0) {
+ gras_msg_init();
+ gras_trp_init();
+ gras_datadesc_init();
+ }
}
/**
void
gras_exit(){
INFO0("Exiting GRAS");
- gras_msg_exit();
- gras_trp_exit();
- gras_datadesc_exit();
+ gras_process_exit();
+ if (--gras_running_process == 0) {
+ gras_msg_exit();
+ gras_trp_exit();
+ gras_datadesc_exit();
+ }
gras_log_exit();
DEBUG0("Exited GRAS");
}