Skip to content

Commit

Permalink
Merge pull request #747 from lsst/tickets/DM-41478
Browse files Browse the repository at this point in the history
DM-41478: Making a maskedImage with None segfaults
  • Loading branch information
mwittgen authored Oct 15, 2024
2 parents b167e1a + 2d2041a commit fda6b12
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 1 deletion.
3 changes: 2 additions & 1 deletion src/image/MaskedImage.cc
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,8 @@ MaskedImage<ImagePixelT, MaskPixelT, VariancePixelT>::MaskedImage(
template <typename ImagePixelT, typename MaskPixelT, typename VariancePixelT>
MaskedImage<ImagePixelT, MaskPixelT, VariancePixelT>::MaskedImage(ImagePtr image, MaskPtr mask,
VariancePtr variance)
: _image(image), _mask(mask), _variance(variance) {
: _image(image != nullptr ? image : std::make_shared<Image>()),
_mask(mask), _variance(variance) {
conformSizes();
}

Expand Down
6 changes: 6 additions & 0 deletions tests/test_maskedImage.py
Original file line number Diff line number Diff line change
Expand Up @@ -745,6 +745,12 @@ def testTicket653(self):
mi = afwImage.MaskedImageF(im)
afwImage.ExposureF(mi)

def testTicket41478(self):
"""Test for DM-41478 fix"""
masked_image = afwImage.MaskedImageF(None)
image = afwImage.ImageF(None)
self.assertEqual(masked_image.getBBox(), image.getBBox())

def testMaskedImageInitialisation(self):
dims = self.mimage.getDimensions()
factory = self.mimage.Factory
Expand Down

0 comments on commit fda6b12

Please sign in to comment.