From c8d0127f3113a5287b5b13d0a57fe9fb88e9db18 Mon Sep 17 00:00:00 2001 From: amaitland Date: Mon, 8 May 2017 13:22:57 +1000 Subject: [PATCH] In rare cases CefStreamReader::CreateForFile returns null - rather than causing a hard crash, log the error and return NULL --- CefSharp.Core/Internals/ClientAdapter.cpp | 14 +++++++++++++- CefSharp.Core/SchemeHandlerFactoryWrapper.h | 14 +++++++++++++- 2 files changed, 26 insertions(+), 2 deletions(-) diff --git a/CefSharp.Core/Internals/ClientAdapter.cpp b/CefSharp.Core/Internals/ClientAdapter.cpp index 9231c0a2a1..ede5a4e885 100644 --- a/CefSharp.Core/Internals/ClientAdapter.cpp +++ b/CefSharp.Core/Internals/ClientAdapter.cpp @@ -704,7 +704,19 @@ namespace CefSharp { auto resourceHandler = static_cast(handler); - return new CefStreamResourceHandler(StringUtils::ToNative(resourceHandler->MimeType), CefStreamReader::CreateForFile(StringUtils::ToNative(resourceHandler->FilePath))); + auto streamReader = CefStreamReader::CreateForFile(StringUtils::ToNative(resourceHandler->FilePath)); + + if (streamReader.get()) + { + return new CefStreamResourceHandler(StringUtils::ToNative(resourceHandler->MimeType), streamReader); + } + else + { + auto msg = "Unable to load resource CefStreamReader::CreateForFile returned NULL for file:" + resourceHandler->FilePath; + LOG(ERROR) << StringUtils::ToNative(msg).ToString(); + + return NULL; + } } else if (handler->GetType() == ByteArrayResourceHandler::typeid) { diff --git a/CefSharp.Core/SchemeHandlerFactoryWrapper.h b/CefSharp.Core/SchemeHandlerFactoryWrapper.h index 2ca2c5f38c..4bb2100aaa 100644 --- a/CefSharp.Core/SchemeHandlerFactoryWrapper.h +++ b/CefSharp.Core/SchemeHandlerFactoryWrapper.h @@ -48,7 +48,19 @@ namespace CefSharp { auto resourceHandler = static_cast(handler); - return new CefStreamResourceHandler(StringUtils::ToNative(resourceHandler->MimeType), CefStreamReader::CreateForFile(StringUtils::ToNative(resourceHandler->FilePath))); + auto streamReader = CefStreamReader::CreateForFile(StringUtils::ToNative(resourceHandler->FilePath)); + + if (streamReader.get()) + { + return new CefStreamResourceHandler(StringUtils::ToNative(resourceHandler->MimeType), streamReader); + } + else + { + auto msg = "Unable to load resource CefStreamReader::CreateForFile returned NULL for file:" + resourceHandler->FilePath; + LOG(ERROR) << StringUtils::ToNative(msg).ToString(); + + return NULL; + } } else if (handler->GetType() == ByteArrayResourceHandler::typeid) {