diff --git a/dom/base/nsContentUtils.cpp b/dom/base/nsContentUtils.cpp index 1abfcd9a1a35..8e3869f34334 100644 --- a/dom/base/nsContentUtils.cpp +++ b/dom/base/nsContentUtils.cpp @@ -7378,27 +7378,28 @@ nsContentUtils::TransferableToIPCTransferable(nsITransferable* aTransferable, RefPtr surface = image->GetFrame(imgIContainer::FRAME_CURRENT, imgIContainer::FLAG_SYNC_DECODE); - if (surface) { - RefPtr dataSurface = - surface->GetDataSurface(); - size_t length; - int32_t stride; - mozilla::UniquePtr surfaceData = - nsContentUtils::GetSurfaceData(dataSurface, &length, &stride); - - IPCDataTransferItem* item = aIPCDataTransfer->items().AppendElement(); - item->flavor() = flavorStr; - // Turn item->data() into an nsCString prior to accessing it. - item->data() = EmptyCString(); - item->data().get_nsCString().Adopt(surfaceData.release(), length); - - IPCDataTransferImage& imageDetails = item->imageDetails(); - mozilla::gfx::IntSize size = dataSurface->GetSize(); - imageDetails.width() = size.width; - imageDetails.height() = size.height; - imageDetails.stride() = stride; - imageDetails.format() = static_cast(dataSurface->GetFormat()); + if (!surface) { + continue; } + RefPtr dataSurface = + surface->GetDataSurface(); + size_t length; + int32_t stride; + mozilla::UniquePtr surfaceData = + nsContentUtils::GetSurfaceData(dataSurface, &length, &stride); + + IPCDataTransferItem* item = aIPCDataTransfer->items().AppendElement(); + item->flavor() = flavorStr; + // Turn item->data() into an nsCString prior to accessing it. + item->data() = EmptyCString(); + item->data().get_nsCString().Adopt(surfaceData.release(), length); + + IPCDataTransferImage& imageDetails = item->imageDetails(); + mozilla::gfx::IntSize size = dataSurface->GetSize(); + imageDetails.width() = size.width; + imageDetails.height() = size.height; + imageDetails.stride() = stride; + imageDetails.format() = static_cast(dataSurface->GetFormat()); continue; }