diff --git a/CHANGELOG.rst b/CHANGELOG.rst index 7d4dd08fa60e654559bca31119bb68cd465b007e..fe480ca09a15abd7fe86ffe77b6ffb3cf4ef50af 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -26,6 +26,15 @@ Changed (!405). +Fixed +^^^^^ + + +* Updated the ```immv``/``imcp`` scripts to honour the ``$FSLOUTPUTTYPE`` + environment variable more closely - conversions between NIFTI1 and + NIFTI2 were not being performed correctly (!405). + + 3.13.3 (Monday 17th July 2023) ------------------------------ diff --git a/fsl/scripts/atlasq.py b/fsl/scripts/atlasq.py index b0ef32a949f8e127f8544442b87fe8cb29980ceb..9e887e688eb6d6893d2bde368c913a7444557947 100644 --- a/fsl/scripts/atlasq.py +++ b/fsl/scripts/atlasq.py @@ -19,20 +19,9 @@ import warnings import logging import numpy as np -# if h5py <= 2.7.1 is installed, -# it will be imported via nibabel, -# and will cause a numpy warning -# to be emitted. -with warnings.catch_warnings(): - warnings.filterwarnings("ignore", category=FutureWarning) - import fsl.data.image as fslimage - -# If wx is not present, then fsl.utils.platform -# will complain that it is not present. -logging.getLogger('fsl.utils.platform').setLevel(logging.ERROR) - -import fsl.data.atlases as fslatlases # noqa -import fsl.version as fslversion # noqa +import fsl.data.image as fslimage +import fsl.data.atlases as fslatlases +import fsl.version as fslversion log = logging.getLogger(__name__) diff --git a/fsl/scripts/fsl_ents.py b/fsl/scripts/fsl_ents.py index 1590c9b4491865c7256a3ccb87a27c047b88b772..2f9a4a0b133378fcf9ffca0be17e4829f39612a6 100644 --- a/fsl/scripts/fsl_ents.py +++ b/fsl/scripts/fsl_ents.py @@ -16,12 +16,8 @@ import warnings import numpy as np -# See atlasq.py for explanation -with warnings.catch_warnings(): - warnings.filterwarnings("ignore", category=FutureWarning) - - import fsl.data.fixlabels as fixlabels - import fsl.data.melodicanalysis as melanalysis +import fsl.data.fixlabels as fixlabels +import fsl.data.melodicanalysis as melanalysis DTYPE = np.float64 diff --git a/fsl/scripts/imcp.py b/fsl/scripts/imcp.py index d2fcc1eda66a6c01f43bbdb246ce46ade699e82f..6ae4d26da4e82588f75367990bcef160a247ed17 100755 --- a/fsl/scripts/imcp.py +++ b/fsl/scripts/imcp.py @@ -14,15 +14,11 @@ The :func:`main` function is essentially a wrapper around the import os.path as op import sys -import warnings +import logging import fsl.utils.path as fslpath - -# See atlasq.py for explanation -with warnings.catch_warnings(): - warnings.filterwarnings("ignore", category=FutureWarning) - import fsl.utils.imcp as imcp - import fsl.data.image as fslimage +import fsl.utils.imcp as imcp +import fsl.data.image as fslimage usage = """Usage: @@ -57,6 +53,11 @@ def main(argv=None): print(usage) return 1 + # When converting to NIFTI2, nibabel + # emits an annoying message via log.warning: + # sizeof_hdr should be 540; set sizeof_hdr to 540 + logging.getLogger('nibabel').setLevel(logging.ERROR) + try: srcs = [fslimage.fixExt(s) for s in srcs] srcs = fslpath.removeDuplicates( diff --git a/fsl/scripts/immv.py b/fsl/scripts/immv.py index febe422747c27558c98cf6243816980837aaa603..0ebfb575dd47b7481bab95535d2b1c4aa862265e 100755 --- a/fsl/scripts/immv.py +++ b/fsl/scripts/immv.py @@ -15,15 +15,11 @@ The :func:`main` function is essentially a wrapper around the import os.path as op import sys -import warnings +import logging import fsl.utils.path as fslpath - -# See atlasq.py for explanation -with warnings.catch_warnings(): - warnings.filterwarnings("ignore", category=FutureWarning) - import fsl.utils.imcp as imcp - import fsl.data.image as fslimage +import fsl.utils.imcp as imcp +import fsl.data.image as fslimage usage = """Usage: @@ -58,6 +54,11 @@ def main(argv=None): print(usage) return 1 + # When converting to NIFTI2, nibabel + # emits an annoying message via log.warning: + # sizeof_hdr should be 540; set sizeof_hdr to 540 + logging.getLogger('nibabel').setLevel(logging.ERROR) + try: srcs = [fslimage.fixExt(s) for s in srcs] srcs = fslpath.removeDuplicates(