From 71901c1c580915ee361d6f7a5fea65b7e034659d Mon Sep 17 00:00:00 2001 From: Tom Close Date: Wed, 14 Feb 2024 11:55:11 +1100 Subject: [PATCH] fixed bug with relative_to using relative paths (ironically) --- xnat_ingest/session.py | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/xnat_ingest/session.py b/xnat_ingest/session.py index ce959fb..5e3ae24 100644 --- a/xnat_ingest/session.py +++ b/xnat_ingest/session.py @@ -405,14 +405,14 @@ def save(self, save_dir: Path, just_manifest: bool = False) -> "ImagingSession": """ scans = {} saved = deepcopy(self) - session_dir = save_dir / self.project_id / self.subject_id / self.session_id + session_dir = ( + save_dir / self.project_id / self.subject_id / self.session_id + ).absolute() session_dir.mkdir(parents=True, exist_ok=True) for scan in self.scans.values(): resources_dict = {} for resource_name, fileset in scan.resources.items(): - resource_dir = ( - session_dir / f"{scan.id}-{scan.type}" / resource_name - ) + resource_dir = session_dir / f"{scan.id}-{scan.type}" / resource_name if not just_manifest: # If data is not already in the save directory, copy it there logger.debug( @@ -421,7 +421,9 @@ def save(self, save_dir: Path, just_manifest: bool = False) -> "ImagingSession": str(fileset.parent), resource_dir, ) - if not fileset.parent.is_relative_to(resource_dir.absolute()): + if not fileset.parent.absolute().is_relative_to( + resource_dir.absolute() + ): resource_dir.mkdir(parents=True, exist_ok=True) fileset = fileset.copy( resource_dir, mode=fileset.CopyMode.hardlink_or_copy @@ -431,7 +433,7 @@ def save(self, save_dir: Path, just_manifest: bool = False) -> "ImagingSession": "datatype": to_mime(fileset, official=False), "fspaths": [ # Ensure it is a relative path using POSIX forward slashes - str(p.relative_to(session_dir)).replace("\\", "/") + str(p.absolute().relative_to(session_dir)).replace("\\", "/") for p in fileset.fspaths ], }