Skip to content

Commit

Permalink
Eliminate initial "_" when suffix is only entity
Browse files Browse the repository at this point in the history
  • Loading branch information
pvandyken committed Feb 23, 2024
1 parent d3f1d74 commit af3738b
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 4 deletions.
16 changes: 12 additions & 4 deletions snakebids/paths/_factory.py
Original file line number Diff line number Diff line change
Expand Up @@ -228,13 +228,21 @@ def bids(

if datatype:
path_parts.append(datatype)
tail = [suffix] if suffix is not None else []
path_parts.append(
"_".join(it.chain(spec_parts[:split], custom_parts, spec_parts[split:]))
"_".join(
it.chain(
spec_parts[:split],
custom_parts,
spec_parts[split:],
tail,
)
)
)
result = os.path.join(*path_parts)
if extension is not None:
result += extension

tail = f"_{suffix}{extension or ''}" if suffix else extension or ""

result = os.path.join(*path_parts) + tail
if custom_parts and _implicit and not in_interactive_session():
wrn_msg = (
f"Path generated with unrecognized entities, and a snakebids spec has "
Expand Down
8 changes: 8 additions & 0 deletions snakebids/tests/test_paths/test_bids.py
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,12 @@ def test_underscore_does_not_precede_extension(
def test_no_underscore_at_end_if_no_suffix(self, entities: dict[str, str]):
assert bids(**entities)[-1] != "_"

@given(entities=_bids_args(nonstandard=True, entities=None))
def test_no_underscore_at_beginning_if_only_suffix(
self, entities: dict[str, str]
):
assert bids(**entities)[0] != "_"

@given(entities=_bids_args(), root=_roots())
def test_beginning_of_path_always_root(
self, entities: dict[str, str], root: str
Expand Down Expand Up @@ -322,4 +328,6 @@ def test_benchmark_bids(benchmark: Benchmark):
england="britain",
space="cosmos",
rome="fell",
suffix="suffix",
extension=".ext",
)

0 comments on commit af3738b

Please sign in to comment.