Skip to content

Commit

Permalink
Expand discussion of bids specs in docs
Browse files Browse the repository at this point in the history
  • Loading branch information
pvandyken committed Feb 1, 2024
1 parent 5f1720f commit 5210c86
Showing 1 changed file with 35 additions and 1 deletion.
36 changes: 35 additions & 1 deletion docs/api/paths.rst
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,47 @@ Specs

.. py:currentmodule:: snakebids.paths.specs
Official specs represent the evolution of the BIDS spec over time. Currently, :func:`~snakebids.bids` uses the :func:`v0_0_0` by default, however, in a future release, this will change to always use the latest spec. Specs may be updated at any time, without warning, even on patch releases, so it's important for production code to explicitly specify the BIDS spec version in use. This is done using :func:`~snakebids.set_bids_spec`:
BIDS specs control the formatting of paths produced by the :func:`~snakebids.bids` function. They specify the order of recognized entities, placing ``ses-X`` after ``sub-Y``, for instance, no matter what order they are specified in the function. Unrecognized entitites are placed in the order specified in the function call.

Because of this, each addition of entities to the spec presents a potentially breaking change. Suppose an entity called ``foo`` were added to the spec. Calls to :func:`~snakebids.bids` with ``foo`` as an argument would place the entity at the end of the path:

.. code-block:: python
from snakebids import bids
# Before foo is in the spec
bids(
subject="001",
session="1",
label="WM",
foo="bar",
suffix="data.nii.gz",
) == "sub-001_ses-1_label-WM_foo-bar_data.nii.gz"
The addition of ``foo`` to the spec might move the position of the entity forward in the output:

.. code-block:: python
# After foo is in the spec
bids(
subject="001",
session="1",
label="WM",
foo="bar",
suffix="data.nii.gz",
) == "sub-001_ses-1_foo-bar_label-WM_data.nii.gz"
This would change the output paths of workflow using this function call, causing a breaking change in workflow behaviour.

To ensure stable path generation across releases, Snakebids ships with versioned specs that can be explicitly set using :func:`snakebids.set_bids_specs`. These specs are named after the snakebids version they release with. By default, :func:`~snakebids.bids` will always use the latest spec, but production code should generally declare the spec to be used by the workflow:

.. code-block:: python
from snakebids import set_bids_spec
set_bids_spec("v0_0_0")
This is especially true of workflows using custom entities. To emphasize this, a warning is issued in python scripts and apps using such entities without declaring a spec version.


.. automodule:: snakebids.paths.specs
:exclude-members: latest
Expand Down

0 comments on commit 5210c86

Please sign in to comment.