- static simgrid::xbt::Extension<Storage, FileSystemStorageExt> EXTENSION_ID;
- explicit FileSystemStorageExt(Storage* ptr);
- ~FileSystemStorageExt();
- std::map<std::string, sg_size_t>* parseContent(std::string filename);
- std::map<std::string, sg_size_t>* getContent() { return content_; }
- sg_size_t getSize() { return size_; }
- sg_size_t getUsedSize() { return usedSize_; }
- void decrUsedSize(sg_size_t size) { usedSize_ -= size; }
- void incrUsedSize(sg_size_t size) { usedSize_ += size; }
-
-private:
- std::map<std::string, sg_size_t>* content_;
- sg_size_t usedSize_ = 0;
- sg_size_t size_ = 0;
+ static simgrid::xbt::Extension<Disk, FileSystemDiskExt> EXTENSION_ID;
+ explicit FileSystemDiskExt(const Disk* ptr);
+ FileSystemDiskExt(const FileSystemDiskExt&) = delete;
+ FileSystemDiskExt& operator=(const FileSystemDiskExt&) = delete;
+ std::map<std::string, sg_size_t, std::less<>>* parse_content(const std::string& filename);
+ std::map<std::string, sg_size_t, std::less<>>* get_content() const { return content_.get(); }
+ const char* get_mount_point() const { return mount_point_.c_str(); }
+ const char* get_mount_point(s4u::Host* remote_host) { return remote_mount_points_[remote_host].c_str(); }
+ void add_remote_mount(Host* host, const std::string& mount_point)
+ {
+ remote_mount_points_.insert({host, mount_point});
+ }
+ sg_size_t get_size() const { return size_; }
+ sg_size_t get_used_size() const { return used_size_; }
+ void decr_used_size(sg_size_t size);
+ void incr_used_size(sg_size_t size);