Skip to content

Commit

Permalink
Improve WIC error reporting (#846)
Browse files Browse the repository at this point in the history
  • Loading branch information
skyline75489 authored Nov 20, 2024
1 parent c3379ec commit 91fa3b5
Showing 1 changed file with 16 additions and 11 deletions.
27 changes: 16 additions & 11 deletions operators/vision/image_decoder_win32.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,14 +15,14 @@
namespace ort_extensions::internal {
struct DecodeImage {
OrtxStatus OnInit() {
HRESULT hr = CoInitializeEx(NULL, COINIT_MULTITHREADED);
HRESULT hr = CoInitializeEx(NULL, COINIT_MULTITHREADED | COINIT_DISABLE_OLE1DDE);
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed when CoInitialize."};
return errorWithHr_("Failed when CoInitialize.", hr);
}
// Create the COM imaging factory
hr = CoCreateInstance(CLSID_WICImagingFactory, NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&pIWICFactory_));
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed to create pIWICFactory."};
return errorWithHr_("Failed to create pIWICFactory.", hr);
}

return {};
Expand Down Expand Up @@ -54,7 +54,7 @@ struct DecodeImage {
// Create a WIC stream to map onto the memory.
HRESULT hr = pIWICFactory_->CreateStream(pIWICStream.put());
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed to create pIWICStream."};
return errorWithHr_("Failed to create pIWICStream.", hr);
}

static_assert(sizeof(uint8_t) == sizeof(unsigned char));
Expand All @@ -72,31 +72,31 @@ struct DecodeImage {
pIDecoder.put() // Pointer to the decoder
);
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed to create pIDecoder."};
return errorWithHr_("Failed to create pIDecoder.", hr);
}

// Retrieve the first bitmap frame.
hr = pIDecoder->GetFrame(0, pIDecoderFrame.put());
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed when pIDecoder->GetFrame."};
return errorWithHr_("Failed when pIDecoder->GetFrame.", hr);
}

// Now get a POINTER to an instance of the Pixel Format
hr = pIDecoderFrame->GetPixelFormat(&pixelFormat);
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed when pIDecoderFrame->GetPixelFormat."};
return errorWithHr_("Failed when pIDecoderFrame->GetPixelFormat.", hr);
}

hr = pIWICFactory_->CreateComponentInfo(pixelFormat, pIComponentInfo.put());
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed when pIWICFactory->CreateComponentInfo."};
return errorWithHr_("Failed when pIWICFactory->CreateComponentInfo.", hr);
}

// Get IWICPixelFormatInfo from IWICComponentInfo
IWICPixelFormatInfo2* pIPixelFormatInfo = NULL;
hr = pIComponentInfo.as(__uuidof(IWICPixelFormatInfo2), reinterpret_cast<void**>(&pIPixelFormatInfo));
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed to query IWICPixelFormatInfo."};
errorWithHr_("Failed to query IWICPixelFormatInfo.", hr);
}

UINT uiWidth = 0;
Expand All @@ -122,7 +122,7 @@ struct DecodeImage {
IWICBitmapSource* pConverted = NULL;
hr = WICConvertBitmapSource(GUID_WICPixelFormat24bppRGB, pIDecoderFrame.get(), &pConverted);
if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed when WICConvertBitmapSource."};
return errorWithHr_("Failed when WICConvertBitmapSource.", hr);
}

// Upcast to make winrt::com_ptr happy. Should be fine because we only use CopyPixels.
Expand All @@ -133,7 +133,7 @@ struct DecodeImage {
hr = pIDecoderFrame->CopyPixels(NULL, rowStride, static_cast<UINT>(output.SizeInBytes()), decoded_image_data);

if (FAILED(hr)) {
return {kOrtxErrorInternal, "[ImageDecoder]: Failed when pIDecoderFrame->CopyPixels."};
return errorWithHr_("Failed when pIDecoderFrame->CopyPixels.", hr);
}

return status;
Expand All @@ -144,6 +144,11 @@ struct DecodeImage {
}

private:
OrtxStatus errorWithHr_(const std::string message, HRESULT hr) const{
return {
kOrtxErrorInternal,
"[ImageDecoder]: " + message + " HRESULT: " + std::to_string(hr)};
}
winrt::com_ptr<IWICImagingFactory> pIWICFactory_;
};
} // namespace ort_extensions::internal

0 comments on commit 91fa3b5

Please sign in to comment.