From 17e20c7c2b9537b8fd470e14d10516fce6d98dc9 Mon Sep 17 00:00:00 2001 From: Matteo Visconti di Oleggio Castello Date: Fri, 21 Jun 2024 14:54:10 -0400 Subject: [PATCH] ENH better handling of temp directory for downloading subjects (#540) --- cortex/tests/test_utils.py | 2 ++ cortex/utils.py | 29 ++++++++++++++++------------- 2 files changed, 18 insertions(+), 13 deletions(-) diff --git a/cortex/tests/test_utils.py b/cortex/tests/test_utils.py index 13cccb0e3..65c1c813c 100644 --- a/cortex/tests/test_utils.py +++ b/cortex/tests/test_utils.py @@ -10,3 +10,5 @@ def test_download_subject(): assert "fsaverage" not in cortex.db.subjects cortex.utils.download_subject(subject_id='fsaverage') assert "fsaverage" in cortex.db.subjects + # test that downloading it again works + cortex.utils.download_subject(subject_id='fsaverage', download_again=True) diff --git a/cortex/utils.py b/cortex/utils.py index ce8c43276..87c6a2426 100644 --- a/cortex/utils.py +++ b/cortex/utils.py @@ -1079,25 +1079,28 @@ def download_subject(subject_id='fsaverage', url=None, pycortex_store=None, "the subject again.".format(subject_id)) return # Map codes to URLs; more coming eventually - id_to_url = dict(fsaverage='https://ndownloader.figshare.com/files/17827577?private_link=4871247dce31e188e758', - ) + id_to_url = dict( + fsaverage='https://ndownloader.figshare.com/files/17827577?private_link=4871247dce31e188e758', + ) if url is None: - if not subject_id in id_to_url: + if subject_id not in id_to_url: raise ValueError('Unknown subject_id!') url = id_to_url[subject_id] - print("Downloading from: {}".format(url)) - # Download to temp dir - tmp_dir = tempfile.gettempdir() - wget.download(url, tmp_dir) - print('Downloaded subject {} to {}'.format(subject_id, tmp_dir)) - # Un-tar to pycortex store + # Setup pycortex store location if pycortex_store is None: # Default location is current filestore in cortex.db pycortex_store = db.filestore - pycortex_store = os.path.expanduser(pycortex_store) - with tarfile.open(os.path.join(tmp_dir, subject_id + '.tar.gz'), "r:gz") as tar: - print("Extracting subject {} to {}".format(subject_id, pycortex_store)) - tar.extractall(path=pycortex_store) + pycortex_store = os.path.abspath(os.path.expanduser(pycortex_store)) + # Download to temp dir + print("Downloading from: {}".format(url)) + with tempfile.TemporaryDirectory() as tmp_dir: + print('Downloading subject {} to {}'.format(subject_id, tmp_dir)) + wget.download(url, tmp_dir) + print('Done downloading') + # Un-tar to pycortex store + with tarfile.open(os.path.join(tmp_dir, subject_id + '.tar.gz'), "r:gz") as tar: + print("Extracting subject {} to {}".format(subject_id, pycortex_store)) + tar.extractall(path=pycortex_store) # reload all subjects from the filestore db.reload_subjects()