From eae59a6bf4f645b052307e2a57e95477ace85d24 Mon Sep 17 00:00:00 2001 From: Remi Gau Date: Thu, 14 Dec 2023 23:29:04 +0100 Subject: [PATCH] override old files and log a warning --- giga_connectome/utils.py | 30 ++++++++---------------------- giga_connectome/workflow.py | 4 ++-- 2 files changed, 10 insertions(+), 24 deletions(-) diff --git a/giga_connectome/utils.py b/giga_connectome/utils.py index 283db50..e439172 100644 --- a/giga_connectome/utils.py +++ b/giga_connectome/utils.py @@ -180,27 +180,13 @@ def get_subject_lists( def check_path(path: Path): - """Check if given path (file or dir) already exists, and if so returns a - new path with _ appended (n being the number of paths with the same name - that exist already). - """ - path = path.resolve() - ext = path.suffix - path_parent = path.parent + """Check if given path (file or dir) already exists. + If so, a warning is logged. + """ + path = path.absolute() if path.exists(): - similar_paths = [ - str(p).replace(ext, "") - for p in path_parent.glob(f"{path.stem}_*{ext}") - ] - existing_numbers = [ - int(p.split("_")[-1]) - for p in similar_paths - if p.split("_")[-1].isdigit() - ] - n = str(max(existing_numbers) + 1) if existing_numbers else "1" - path = path_parent / f"{path.stem}_{n}{ext}" - - gc_log.debug(f"Specified path already exists, using {path} instead.") - - return path + gc_log.warning( + f"Specified path already exists:\n\t{path}\n" + "Old file will be overwritten" + ) diff --git a/giga_connectome/workflow.py b/giga_connectome/workflow.py index 3b6e2e4..ebbe10f 100644 --- a/giga_connectome/workflow.py +++ b/giga_connectome/workflow.py @@ -79,7 +79,7 @@ def workflow(args): f"sub-{subject}_atlas-{atlas['name']}" f"_desc-{strategy['name']}.h5" ) - connectome_path = utils.check_path(connectome_path) + utils.check_path(connectome_path) gc_log.info(f"Generate subject level connectomes: sub-{subject}") @@ -106,7 +106,7 @@ def workflow(args): connectome_path = ( output_dir / f"atlas-{atlas['name']}_desc-{strategy['name']}.h5" ) - connectome_path = utils.check_path(connectome_path) + utils.check_path(connectome_path) gc_log.info(connectome_path) gc_log.info("Generate subject level connectomes")