double *communication_amount,
double rate)=0;
- /**
- * @brief [brief description]
- * @details [long description]
- *
- * @param src [description]
- * @param dst [description]
- *
- * @return [description]
- */
- virtual xbt_dynar_t getRoute(WorkstationPtr src, WorkstationPtr dst)=0;
-
/**
* @brief [brief description]
* @details [long description]
*
* @return The xbt_dict_t of mount_point: Storage
*/
- virtual xbt_dict_t getStorageList();
+ virtual xbt_dict_t getMountedStorageList();
+
+ /**
+ * @brief Get the xbt_dynar_t of storages attached to the workstation
+ *
+ * @return The xbt_dynar_t of Storage names
+ */
+ virtual xbt_dynar_t getAttachedStorageList();
/**
* @brief Open a file
*
- * @param mount The mount point
- * @param path The path to the file
+ * @param fullpath The full path to the file
*
* @return The StorageAction corresponding to the opening
*/
- virtual ActionPtr open(const char* mount, const char* path);
+ virtual ActionPtr open(const char* fullpath);
/**
* @brief Close a file
*/
virtual int fileSeek(surf_file_t fd, sg_size_t offset, int origin);
+ /**
+ * @brief Move a file to another location on the *same mount point*.
+ * @details [long description]
+ *
+ * @param fd The file descriptor
+ * @param fullpath The new full path
+ * @return MSG_OK if successful, MSG_TASK_CANCELED and a warning if the new
+ * full path is not on the same mount point
+ */
+ virtual int fileMove(surf_file_t fd, const char* fullpath);
+
+ /**
+ * @brief Copy a file to another location on a remote host.
+ * @details [long description]
+ *
+ * @param fd The file descriptor
+ * @param host_dest The worstation destination
+ * @param fullpath The new full path
+ * @return MSG_OK if successful, otherwise MSG_TASK_CANCELED
+ */
+ virtual int fileRcopy(surf_file_t fd, surf_resource_t host_dest, const char* fullpath);
+
xbt_dynar_t p_storage;
RoutingEdgePtr p_netElm;
CpuPtr p_cpu;
/**********
* Action *
**********/
+
/** @ingroup SURF_workstation_interface
* @brief SURF workstation action interface class
*/