| Total Complexity | 3 | 
| Total Lines | 29 | 
| Duplicated Lines | 0 % | 
| Changes | 2 | ||
| Bugs | 0 | Features | 0 | 
| 1 | from datetime import datetime | ||
| 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.polaroid = self.dependencies.getPolaroid() | ||
| 11 | self.pictureCache = self.dependencies.getPictureCache() | ||
| 12 | |||
| 13 | def attach(self, form='json'): | ||
| 14 | """ | ||
| 15 | Attach the current provenance to the file by injecting it as a | ||
| 16 | json-encoded extension to the nifti header. | ||
| 17 | |||
| 18 | Args: | ||
| 19 | form (str): Data format in which to serialize provenance. Defaults | ||
| 20 | to 'json'. | ||
| 21 | """ | ||
| 22 | img = self.libs.nibabel.load(self.path) | ||
| 23 | provstr = self.getProvenance(form) | ||
| 24 |         ext = self.libs.nibabel.nifti1.Nifti1Extension('comment', provstr) | ||
| 25 | hdr = img.get_header() | ||
| 26 | hdr.extensions.append(ext) | ||
| 27 | img.to_filename(self.path) | ||
| 28 | |||
| 29 | def inspect(self): | ||
| 30 | provenance = super(NiftiFile, self).inspect() | ||
| 31 | img = self.libs.nibabel.load(self.path) | ||
| 32 | self.polaroid.saveSnapshot(img.get_data(), to=self.pictureCache) | ||
| 33 | return provenance | ||
| 34 |