-}
-
-const char* xbt_procname(void) {
- const char *res = NULL;
- smx_process_t process = SIMIX_process_self();
- if ((process != NULL) && (process->simdata))
- res = SIMIX_process_get_name(process);
- if (res)
- return res;
- else
- return "";
-}
-
-int gras_os_getpid(void) {
-
- smx_process_t process = SIMIX_process_self();
-
- if ((process != NULL) && (process->data))
- return ((gras_procdata_t*)process->data)->pid;
- else
- return 0;
+}
+
+/** @brief retrieve the value of a given process property (or NULL if not defined) */
+const char *gras_process_property_value(const char *name)
+{
+ return xbt_dict_get_or_null(SIMIX_req_process_get_properties
+ (SIMIX_process_self()), name);
+}
+
+/** @brief retrieve the process properties dictionnary
+ * @warning it's the original one, not a copy. Don't mess with it
+ */
+xbt_dict_t gras_process_properties(void)
+{
+ return SIMIX_req_process_get_properties(SIMIX_process_self());
+}
+
+/* **************************************************************************
+ * OS virtualization function
+ * **************************************************************************/
+
+
+int gras_os_getpid(void)
+{
+ gras_procdata_t *data;
+ data = (gras_procdata_t *) SIMIX_process_self_get_data();
+ if (data != NULL)
+ return data->pid;
+
+ return 0;
+}
+
+/** @brief retrieve the value of a given host property (or NULL if not defined) */
+const char *gras_os_host_property_value(const char *name)
+{
+ return
+ xbt_dict_get_or_null(SIMIX_req_host_get_properties
+ (SIMIX_req_process_get_host(SIMIX_process_self())),
+ name);
+}
+
+/** @brief retrieve the host properties dictionary
+ * @warning it's the original one, not a copy. Don't mess with it
+ */
+xbt_dict_t gras_os_host_properties(void)
+{
+ return
+ SIMIX_req_host_get_properties(SIMIX_req_process_get_host
+ (SIMIX_process_self()));
+}
+
+/* **************************************************************************
+ * Interface with SIMIX
+ * (these functions are called by the stuff generated by gras_stub_generator)
+ * **************************************************************************/
+
+XBT_LOG_EXTERNAL_CATEGORY(gras_trp);
+XBT_LOG_EXTERNAL_CATEGORY(gras_trp_sg);
+
+void gras_global_init(int *argc, char **argv)
+{
+ XBT_LOG_CONNECT(gras_trp_sg, gras_trp);
+ SIMIX_global_init(argc, argv);
+}
+
+void gras_create_environment(const char *file)
+{
+ SIMIX_create_environment(file);
+}
+
+void gras_function_register(const char *name, xbt_main_func_t code)
+{
+ SIMIX_function_register(name, code);
+}
+
+void gras_function_register_default(xbt_main_func_t code)
+{
+ SIMIX_function_register_default(code);
+}
+
+void gras_main()
+{
+ /* Clean IO before the run */
+ fflush(stdout);
+ fflush(stderr);
+ SIMIX_run();
+
+ return;
+}
+
+void gras_launch_application(const char *file)
+{
+ SIMIX_launch_application(file);
+}
+
+void gras_load_environment_script(const char *script_file)
+{
+#ifdef HAVE_LUA
+ lua_State *L = lua_open();
+ luaL_openlibs(L);
+
+ if (luaL_loadfile(L, script_file) || lua_pcall(L, 0, 0, 0)) {
+ printf("error: %s\n", lua_tostring(L, -1));
+ return;
+ }
+#else
+ xbt_die
+ ("Lua is not available!! to call gras_load_environment_script, lua should be available...");
+#endif
+ return;
+}
+
+void gras_clean()
+{
+ SIMIX_clean();