Completed
Pull Request — master (#136)
by Jasper
01:18
created

NiftiFile   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 28
Duplicated Lines 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
dl 0
loc 28
rs 10
c 2
b 0
f 0
wmc 3

3 Methods

Rating   Name   Duplication   Size   Complexity  
A attach() 0 15 1
A inspect() 0 5 1
A __init__() 0 4 1
1
from datetime import datetime
2
from niprov.basefile import BaseFile
3
4
5
class NiftiFile(BaseFile):
6
7
    def __init__(self, location, **kwargs):
8
        super(NiftiFile, self).__init__(location, **kwargs)
9
        self.libs = self.dependencies.getLibraries()
10
        self.camera = self.dependencies.getCamera()
11
12
    def attach(self, form='json'):
13
        """
14
        Attach the current provenance to the file by injecting it as a 
15
        json-encoded extension to the nifti header.
16
17
        Args:
18
            form (str): Data format in which to serialize provenance. Defaults 
19
                to 'json'.
20
        """
21
        img = self.libs.nibabel.load(self.path)
22
        provstr = self.getProvenance(form)
23
        ext = self.libs.nibabel.nifti1.Nifti1Extension('comment', provstr)
24
        hdr = img.get_header()
25
        hdr.extensions.append(ext)
26
        img.to_filename(self.path)
27
28
    def inspect(self):
29
        provenance = super(NiftiFile, self).inspect()
30
        img = self.libs.nibabel.load(self.path)
31
        self.camera.saveSnapshot(img.get_data(), for_=self)
32
        return provenance
33