11 #ifndef WRENCH_DATAMOVEMENTMANAGER_H
12 #define WRENCH_DATAMOVEMENTMANAGER_H
15 #include "wrench/simgrid_S4U_util/S4U_Daemon.h"
31 class DataMovementManager :
public Service {
39 void initiateAsynchronousFileCopy(WorkflowFile *file,
40 std::shared_ptr<FileLocation> src,
41 std::shared_ptr<FileLocation> dst,
42 std::shared_ptr<FileRegistryService> file_registry_service=
nullptr);
44 void doSynchronousFileCopy(WorkflowFile *file,
45 std::shared_ptr<FileLocation> src,
46 std::shared_ptr<FileLocation> dst,
47 std::shared_ptr<FileRegistryService> file_registry_service=
nullptr);
58 explicit DataMovementManager(std::shared_ptr<WMS> wms);
68 std::shared_ptr<WMS> wms =
nullptr;
70 bool processNextMessage();
72 struct CopyRequestSpecs {
74 std::shared_ptr<FileLocation> src;
75 std::shared_ptr<FileLocation> dst;
76 std::shared_ptr<FileRegistryService> file_registry_service;
78 CopyRequestSpecs(WorkflowFile *file,
79 std::shared_ptr<FileLocation> src,
80 std::shared_ptr<FileLocation> dst,
81 std::shared_ptr<FileRegistryService> file_registry_service) :
82 file(file), src(src), dst(dst), file_registry_service(file_registry_service) {}
84 bool operator==(
const CopyRequestSpecs &rhs)
const {
85 return (file == rhs.file) &&
86 (dst->getStorageService() == rhs.dst->getStorageService()) &&
87 (dst->getAbsolutePathAtMountPoint() == rhs.dst->getAbsolutePathAtMountPoint());
91 std::list<std::unique_ptr<CopyRequestSpecs>> pending_file_copies;
102 #endif //WRENCH_DATAMOVEMENTMANAGER_H