X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/121e1dc6ee0462b6f6f1f1570b0f48c61ee4ff9a..600e50aa1f50cbdfd2d20c6b2bcea8a0908d4416:/src/s4u/s4u_file.cpp diff --git a/src/s4u/s4u_file.cpp b/src/s4u/s4u_file.cpp index fafc21dd17..e63eba2f63 100644 --- a/src/s4u/s4u_file.cpp +++ b/src/s4u/s4u_file.cpp @@ -12,20 +12,25 @@ #include "simgrid/s4u/File.hpp" #include "simgrid/s4u/Host.hpp" #include "simgrid/s4u/Mailbox.hpp" +#include "simgrid/s4u/Storage.hpp" XBT_LOG_NEW_DEFAULT_CATEGORY(s4u_file,"S4U files"); - namespace simgrid { namespace s4u { File::File(const char* fullpath, void* userdata) : path_(fullpath), userdata_(userdata) { // this cannot fail because we get a xbt_die if the mountpoint does not exist - pimpl_ = simcall_file_open(fullpath, Host::current()); + pimpl_ = simcall_file_open(fullpath, Host::current()); + xbt_dynar_t info = simcall_file_get_info(pimpl_); + storage_type = xbt_dynar_pop_as(info, char*); + storageId = xbt_dynar_pop_as(info, char*); + mount_point = xbt_dynar_pop_as(info, char*); } File::~File() { + // Host::current()->extension()->file_descriptor_table->push_back(desc_id_); simcall_file_close(pimpl_, Host::current()); }