2024-01-19 00:55:55 +00:00
|
|
|
#ifndef FLUTTER_INAPPWEBVIEW_PLUGIN_LOG_UTIL_H_
|
|
|
|
#define FLUTTER_INAPPWEBVIEW_PLUGIN_LOG_UTIL_H_
|
|
|
|
|
|
|
|
#include <comdef.h>
|
|
|
|
#include <iostream>
|
|
|
|
#include <string>
|
2024-01-19 17:52:00 +00:00
|
|
|
#include <type_traits>
|
2024-01-19 00:55:55 +00:00
|
|
|
|
|
|
|
#include "strconv.h"
|
|
|
|
|
|
|
|
namespace flutter_inappwebview_plugin
|
|
|
|
{
|
2024-01-19 17:52:00 +00:00
|
|
|
template <typename T>
|
|
|
|
static inline void debugLog(const std::basic_string<T>& msg, const bool& isError = false)
|
2024-01-19 00:55:55 +00:00
|
|
|
{
|
|
|
|
#ifndef NDEBUG
|
|
|
|
if (isError) {
|
|
|
|
std::cerr << msg << std::endl;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
std::cout << msg << std::endl;
|
|
|
|
}
|
|
|
|
OutputDebugString(ansi_to_wide(msg + "\n").c_str());
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2024-01-19 17:52:00 +00:00
|
|
|
static inline void debugLog(const char* msg, const bool& isError = false)
|
|
|
|
{
|
|
|
|
debugLog(std::string(msg), isError);
|
|
|
|
}
|
|
|
|
|
2024-01-19 00:55:55 +00:00
|
|
|
static inline void debugLog(const std::wstring& msg, const bool& isError = false)
|
|
|
|
{
|
|
|
|
debugLog(wide_to_ansi(msg), isError);
|
|
|
|
}
|
|
|
|
|
2024-01-19 17:52:00 +00:00
|
|
|
static inline void debugLog(const bool& value, const bool& isError = false)
|
|
|
|
{
|
|
|
|
debugLog(value ? "true" : "false", isError);
|
|
|
|
}
|
|
|
|
|
|
|
|
template<
|
|
|
|
typename T,
|
|
|
|
typename = typename std::enable_if<std::is_arithmetic<T>::value, T>::type
|
|
|
|
>
|
|
|
|
static inline void debugLog(const T& value, const bool& isError = false)
|
|
|
|
{
|
|
|
|
debugLog(std::to_string(value), isError);
|
|
|
|
}
|
|
|
|
|
2024-01-19 00:55:55 +00:00
|
|
|
static inline std::string getHRMessage(const HRESULT& error)
|
|
|
|
{
|
|
|
|
return wide_to_ansi(_com_error(error).ErrorMessage());
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void debugLog(const HRESULT& hr)
|
|
|
|
{
|
|
|
|
auto isError = hr != S_OK;
|
|
|
|
debugLog((isError ? "Error: " : "Message: ") + getHRMessage(hr), isError);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool succeededOrLog(const HRESULT& hr)
|
|
|
|
{
|
|
|
|
if (SUCCEEDED(hr)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
debugLog(hr);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool failedAndLog(const HRESULT& hr)
|
|
|
|
{
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
debugLog(hr);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void failedLog(const HRESULT& hr)
|
|
|
|
{
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
debugLog(hr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif //FLUTTER_INAPPWEBVIEW_PLUGIN_LOG_UTIL_H_
|