From ca5ba76e74e2d182b0dd2af52e95a5850da089d6 Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sat, 4 May 2024 18:36:24 +0200 Subject: [PATCH 1/8] STY: Apply ruff/pyupgrade rule UP031 New in ruff v0.4.2 --- .maint/paper_author_list.py | 23 +++++++++++++---------- .maint/update_authors.py | 20 +++++++++++--------- .maint/update_zenodo.py | 7 ++++--- fmriprep/cli/parser.py | 10 +++++----- fmriprep/cli/run.py | 2 +- fmriprep/cli/workflow.py | 4 +--- fmriprep/utils/bids.py | 4 ++-- fmriprep/workflows/base.py | 2 +- fmriprep/workflows/bold/resampling.py | 2 +- 9 files changed, 39 insertions(+), 35 deletions(-) diff --git a/.maint/paper_author_list.py b/.maint/paper_author_list.py index a6300c635..5b3b8e6dd 100755 --- a/.maint/paper_author_list.py +++ b/.maint/paper_author_list.py @@ -46,23 +46,26 @@ def _aslist(inlist): ] print( - 'Some people made commits, but are missing in .maint/ ' - 'files: %s.' % ', '.join(unmatched), + 'Some people made commits, but are missing in .maint/ ' 'files: {}.'.format( + ', '.join(unmatched) + ), file=sys.stderr, ) print('Authors (%d):' % len(author_matches)) print( - '%s.' - % '; '.join( - [ - '{} \\ :sup:`{}`\\ '.format(i['name'], idx) - for i, idx in zip(author_matches, aff_indexes, strict=False) - ] + '{}.'.format( + '; '.join( + [ + '{} \\ :sup:`{}`\\ '.format(i['name'], idx) + for i, idx in zip(author_matches, aff_indexes, strict=False) + ] + ) ) ) print( - '\n\nAffiliations:\n%s' - % '\n'.join([f'{i + 1: >2}. {a}' for i, a in enumerate(affiliations)]) + '\n\nAffiliations:\n{}'.format( + '\n'.join([f'{i + 1: >2}. {a}' for i, a in enumerate(affiliations)]) + ) ) diff --git a/.maint/update_authors.py b/.maint/update_authors.py index 263f88631..7d0bbfa69 100755 --- a/.maint/update_authors.py +++ b/.maint/update_authors.py @@ -206,7 +206,7 @@ def zenodo( if isinstance(creator['affiliation'], list): creator['affiliation'] = creator['affiliation'][0] - Path(zenodo_file).write_text('%s\n' % json.dumps(zenodo, indent=2)) + Path(zenodo_file).write_text(f'{json.dumps(zenodo, indent=2)}\n') @cli.command() @@ -274,18 +274,20 @@ def _aslist(value): print('Authors (%d):' % len(hits)) print( - '%s.' - % '; '.join( - [ - '{} \\ :sup:`{}`\\ '.format(i['name'], idx) - for i, idx in zip(hits, aff_indexes, strict=False) - ] + '{}.'.format( + '; '.join( + [ + '{} \\ :sup:`{}`\\ '.format(i['name'], idx) + for i, idx in zip(hits, aff_indexes, strict=False) + ] + ) ) ) print( - '\n\nAffiliations:\n%s' - % '\n'.join([f'{i + 1: >2}. {a}' for i, a in enumerate(affiliations)]) + '\n\nAffiliations:\n{}'.format( + '\n'.join([f'{i + 1: >2}. {a}' for i, a in enumerate(affiliations)]) + ) ) diff --git a/.maint/update_zenodo.py b/.maint/update_zenodo.py index 5b30707b8..e52c345b5 100755 --- a/.maint/update_zenodo.py +++ b/.maint/update_zenodo.py @@ -145,8 +145,9 @@ def loads_contributors(s): zenodo['contributors'] = zen_contributors print( - 'Some people made commits, but are missing in .maint/ ' - 'files: %s.' % ', '.join(set(miss_creators).intersection(miss_contributors)), + 'Some people made commits, but are missing in .maint/ ' 'files: {}.'.format( + ', '.join(set(miss_creators).intersection(miss_contributors)) + ), file=sys.stderr, ) @@ -162,4 +163,4 @@ def loads_contributors(s): if isinstance(creator['affiliation'], list): creator['affiliation'] = creator['affiliation'][0] - zenodo_file.write_text('%s\n' % json.dumps(zenodo, indent=2, ensure_ascii=False)) + zenodo_file.write_text(f'{json.dumps(zenodo, indent=2, ensure_ascii=False)}\n') diff --git a/fmriprep/cli/parser.py b/fmriprep/cli/parser.py index 61922b6ee..c7df064e8 100644 --- a/fmriprep/cli/parser.py +++ b/fmriprep/cli/parser.py @@ -881,10 +881,9 @@ def parse_args(args=None, namespace=None): if output_dir == bids_dir: parser.error( 'The selected output folder is the same as the input BIDS folder. ' - 'Please modify the output path (suggestion: %s).' - % bids_dir + f'Please modify the output path (suggestion: {bids_dir}).' / 'derivatives' - / ('fmriprep-%s' % version.split('+')[0]) + / ('fmriprep-{}'.format(version.split('+')[0])) ) if bids_dir in work_dir.parents: @@ -924,8 +923,9 @@ def parse_args(args=None, namespace=None): missing_subjects = participant_label - set(all_subjects) if missing_subjects: parser.error( - 'One or more participant labels were not found in the BIDS directory: ' - '%s.' % ', '.join(missing_subjects) + 'One or more participant labels were not found in the BIDS directory: ' '{}.'.format( + ', '.join(missing_subjects) + ) ) config.execution.participant_label = sorted(participant_label) diff --git a/fmriprep/cli/run.py b/fmriprep/cli/run.py index af4ffad4b..6c07813d6 100644 --- a/fmriprep/cli/run.py +++ b/fmriprep/cli/run.py @@ -147,7 +147,7 @@ def main(): config.loggers.workflow.log( 15, - '\n'.join(['fMRIPrep config:'] + ['\t\t%s' % s for s in config.dumps().splitlines()]), + '\n'.join(['fMRIPrep config:'] + [f'\t\t{s}' for s in config.dumps().splitlines()]), ) config.loggers.workflow.log(25, 'fMRIPrep started!') errno = 1 # Default is error exit unless otherwise set diff --git a/fmriprep/cli/workflow.py b/fmriprep/cli/workflow.py index 5d62545e6..b47b70d4e 100644 --- a/fmriprep/cli/workflow.py +++ b/fmriprep/cli/workflow.py @@ -173,9 +173,7 @@ def build_boilerplate(config_file, workflow): config.load(config_file) logs_path = config.execution.fmriprep_dir / 'logs' boilerplate = workflow.visit_desc() - citation_files = { - ext: logs_path / ('CITATION.%s' % ext) for ext in ('bib', 'tex', 'md', 'html') - } + citation_files = {ext: logs_path / (f'CITATION.{ext}') for ext in ('bib', 'tex', 'md', 'html')} if boilerplate: # To please git-annex users and also to guarantee consistency diff --git a/fmriprep/utils/bids.py b/fmriprep/utils/bids.py index ef58916cc..0bdc03ff1 100644 --- a/fmriprep/utils/bids.py +++ b/fmriprep/utils/bids.py @@ -66,7 +66,7 @@ def collect_derivatives( item = layout.get(return_type='filename', **query) if not item: continue - derivs_cache['%s_boldref' % k] = item[0] if len(item) == 1 else item + derivs_cache[f'{k}_boldref'] = item[0] if len(item) == 1 else item for xfm, q in spec['transforms'].items(): query = {**q, **entities} @@ -237,7 +237,7 @@ def validate_input_dir(exec_env, bids_dir, participant_label, need_T1w=True): ignored_subs = all_subs.difference(selected_subs) if ignored_subs: for sub in ignored_subs: - validator_config_dict['ignoredFiles'].append('/sub-%s/**' % sub) + validator_config_dict['ignoredFiles'].append(f'/sub-{sub}/**') with tempfile.NamedTemporaryFile(mode='w+', suffix='.json') as temp: temp.write(json.dumps(validator_config_dict)) temp.flush() diff --git a/fmriprep/workflows/base.py b/fmriprep/workflows/base.py index d7387b5ee..78cd17a3c 100644 --- a/fmriprep/workflows/base.py +++ b/fmriprep/workflows/base.py @@ -84,7 +84,7 @@ def init_fmriprep_wf(): spaces=config.workflow.spaces.get_fs_spaces(), minimum_fs_version='7.0.0', ), - name='fsdir_run_%s' % config.execution.run_uuid.replace('-', '_'), + name='fsdir_run_{}'.format(config.execution.run_uuid.replace('-', '_')), run_without_submitting=True, ) if config.execution.fs_subjects_dir is not None: diff --git a/fmriprep/workflows/bold/resampling.py b/fmriprep/workflows/bold/resampling.py index 696318ff4..37558f68b 100644 --- a/fmriprep/workflows/bold/resampling.py +++ b/fmriprep/workflows/bold/resampling.py @@ -126,7 +126,7 @@ def init_bold_surf_wf( The BOLD time-series were resampled onto the following surfaces (FreeSurfer reconstruction nomenclature): {out_spaces}. -""".format(out_spaces=', '.join(['*%s*' % s for s in surface_spaces])) +""".format(out_spaces=', '.join([f'*{s}*' for s in surface_spaces])) inputnode = pe.Node( niu.IdentityInterface( From 98c0534a8b6f76af0de3a5ea735d591e0842bc4a Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos Orfanos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sat, 4 May 2024 20:43:52 +0200 Subject: [PATCH 2/8] Update .maint/paper_author_list.py Co-authored-by: Chris Markiewicz --- .maint/paper_author_list.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.maint/paper_author_list.py b/.maint/paper_author_list.py index 5b3b8e6dd..0a06e92f4 100755 --- a/.maint/paper_author_list.py +++ b/.maint/paper_author_list.py @@ -46,7 +46,7 @@ def _aslist(inlist): ] print( - 'Some people made commits, but are missing in .maint/ ' 'files: {}.'.format( + 'Some people made commits, but are missing in .maint/ files: {}.'.format( ', '.join(unmatched) ), file=sys.stderr, From 11452269e8c4bfdcbbe96fad00dead1cb7a89965 Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos Orfanos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sat, 4 May 2024 20:43:58 +0200 Subject: [PATCH 3/8] Update .maint/paper_author_list.py Co-authored-by: Chris Markiewicz --- .maint/paper_author_list.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.maint/paper_author_list.py b/.maint/paper_author_list.py index 0a06e92f4..c10bd5c71 100755 --- a/.maint/paper_author_list.py +++ b/.maint/paper_author_list.py @@ -57,7 +57,7 @@ def _aslist(inlist): '{}.'.format( '; '.join( [ - '{} \\ :sup:`{}`\\ '.format(i['name'], idx) + rf'{i["name"]} \ :sup:`{idx}`\ ' for i, idx in zip(author_matches, aff_indexes, strict=False) ] ) From 6481f6c69ee83e7610e2fe70c143f4b4797c1680 Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos Orfanos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sat, 4 May 2024 21:09:41 +0200 Subject: [PATCH 4/8] Update .maint/update_authors.py Co-authored-by: Chris Markiewicz --- .maint/update_authors.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.maint/update_authors.py b/.maint/update_authors.py index 7d0bbfa69..4bf9cf1a7 100755 --- a/.maint/update_authors.py +++ b/.maint/update_authors.py @@ -277,7 +277,7 @@ def _aslist(value): '{}.'.format( '; '.join( [ - '{} \\ :sup:`{}`\\ '.format(i['name'], idx) + rf'{i["name"]} \ :sup:`{idx}`\ ' for i, idx in zip(hits, aff_indexes, strict=False) ] ) From 8583b19a318e71e06f9a21a51e1ff1c7e09eda11 Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos Orfanos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sat, 4 May 2024 21:09:52 +0200 Subject: [PATCH 5/8] Update fmriprep/cli/parser.py Co-authored-by: Chris Markiewicz --- fmriprep/cli/parser.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/fmriprep/cli/parser.py b/fmriprep/cli/parser.py index c7df064e8..8687c8f20 100644 --- a/fmriprep/cli/parser.py +++ b/fmriprep/cli/parser.py @@ -881,8 +881,9 @@ def parse_args(args=None, namespace=None): if output_dir == bids_dir: parser.error( 'The selected output folder is the same as the input BIDS folder. ' - f'Please modify the output path (suggestion: {bids_dir}).' - / 'derivatives' + 'Please modify the output path (suggestion: {}).'.format( + bids_dir / 'derivatives' / f'fmriprep-{version.split("+")[0]}' + ) / ('fmriprep-{}'.format(version.split('+')[0])) ) From 5a02b2dee5fc7e5e2a9ca3fdd96e2ed33243f780 Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos Orfanos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sat, 4 May 2024 21:10:37 +0200 Subject: [PATCH 6/8] Update fmriprep/cli/workflow.py Co-authored-by: Chris Markiewicz --- fmriprep/cli/workflow.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/fmriprep/cli/workflow.py b/fmriprep/cli/workflow.py index b47b70d4e..35140221a 100644 --- a/fmriprep/cli/workflow.py +++ b/fmriprep/cli/workflow.py @@ -173,7 +173,7 @@ def build_boilerplate(config_file, workflow): config.load(config_file) logs_path = config.execution.fmriprep_dir / 'logs' boilerplate = workflow.visit_desc() - citation_files = {ext: logs_path / (f'CITATION.{ext}') for ext in ('bib', 'tex', 'md', 'html')} + citation_files = {ext: logs_path / f'CITATION.{ext}' for ext in ('bib', 'tex', 'md', 'html')} if boilerplate: # To please git-annex users and also to guarantee consistency From 07ad73138fcb1e623231cd06c41486741c96945e Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sat, 4 May 2024 22:05:08 +0200 Subject: [PATCH 7/8] STY: Apply ruff/flake8-implicit-str-concat rule ISC001 ISC001 Implicitly concatenated string literals on one line This rule is currently disabled because it conflicts with the formatter: https://github.com/astral-sh/ruff/issues/8272 --- .maint/update_authors.py | 4 ++-- .maint/update_zenodo.py | 2 +- fmriprep/cli/parser.py | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.maint/update_authors.py b/.maint/update_authors.py index 4bf9cf1a7..55e526e92 100755 --- a/.maint/update_authors.py +++ b/.maint/update_authors.py @@ -187,7 +187,7 @@ def zenodo( misses = set(miss_creators).intersection(miss_contributors) if misses: print( - "Some people made commits, but are missing in .maint/ " f"files: {', '.join(misses)}", + f"Some people made commits, but are missing in .maint/ files: {', '.join(misses)}", file=sys.stderr, ) @@ -268,7 +268,7 @@ def _aslist(value): if misses: print( - "Some people made commits, but are missing in .maint/ " f"files: {', '.join(misses)}", + f"Some people made commits, but are missing in .maint/ files: {', '.join(misses)}", file=sys.stderr, ) diff --git a/.maint/update_zenodo.py b/.maint/update_zenodo.py index e52c345b5..a31f535c4 100755 --- a/.maint/update_zenodo.py +++ b/.maint/update_zenodo.py @@ -145,7 +145,7 @@ def loads_contributors(s): zenodo['contributors'] = zen_contributors print( - 'Some people made commits, but are missing in .maint/ ' 'files: {}.'.format( + 'Some people made commits, but are missing in .maint/ files: {}.'.format( ', '.join(set(miss_creators).intersection(miss_contributors)) ), file=sys.stderr, diff --git a/fmriprep/cli/parser.py b/fmriprep/cli/parser.py index 8687c8f20..7d771183d 100644 --- a/fmriprep/cli/parser.py +++ b/fmriprep/cli/parser.py @@ -924,7 +924,7 @@ def parse_args(args=None, namespace=None): missing_subjects = participant_label - set(all_subjects) if missing_subjects: parser.error( - 'One or more participant labels were not found in the BIDS directory: ' '{}.'.format( + 'One or more participant labels were not found in the BIDS directory: {}.'.format( ', '.join(missing_subjects) ) ) From a16071ba7233ddece4bda11d969c9890b0652068 Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos Orfanos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sat, 4 May 2024 22:46:37 +0200 Subject: [PATCH 8/8] Update fmriprep/cli/parser.py Co-authored-by: Chris Markiewicz --- fmriprep/cli/parser.py | 1 - 1 file changed, 1 deletion(-) diff --git a/fmriprep/cli/parser.py b/fmriprep/cli/parser.py index 7d771183d..63b4cd9d4 100644 --- a/fmriprep/cli/parser.py +++ b/fmriprep/cli/parser.py @@ -884,7 +884,6 @@ def parse_args(args=None, namespace=None): 'Please modify the output path (suggestion: {}).'.format( bids_dir / 'derivatives' / f'fmriprep-{version.split("+")[0]}' ) - / ('fmriprep-{}'.format(version.split('+')[0])) ) if bids_dir in work_dir.parents: