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"
|
2024-01-20 21:13:24 +00:00
|
|
|
#include "string.h"
|
2024-01-19 00:55:55 +00:00
|
|
|
|
|
|
|
namespace flutter_inappwebview_plugin
|
|
|
|
{
|
2024-01-19 17:52:00 +00:00
|
|
|
template <typename T>
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline void debugLog(const std::basic_string<T>& msg, const bool& isError = false, const std::string& filename = "", const int& line = 0)
|
2024-01-19 00:55:55 +00:00
|
|
|
{
|
|
|
|
#ifndef NDEBUG
|
2024-01-20 21:13:24 +00:00
|
|
|
std::basic_string<T> debugMsg = msg;
|
|
|
|
if (!filename.empty() && line > 0) {
|
|
|
|
auto filenameSplit = split(filename, std::string{ "\\flutter_inappwebview_windows\\" });
|
|
|
|
std::string reduceFilenamePath = filenameSplit.size() > 0 ? "flutter_inappwebview_windows\\" + filenameSplit.back() : filename;
|
|
|
|
debugMsg = reduceFilenamePath + "(" + std::to_string(line) + "): " + debugMsg;
|
|
|
|
}
|
2024-01-19 00:55:55 +00:00
|
|
|
if (isError) {
|
2024-01-20 21:13:24 +00:00
|
|
|
std::cerr << debugMsg << std::endl;
|
2024-01-19 00:55:55 +00:00
|
|
|
}
|
|
|
|
else {
|
2024-01-20 21:13:24 +00:00
|
|
|
std::cout << debugMsg << std::endl;
|
2024-01-19 00:55:55 +00:00
|
|
|
}
|
2024-01-20 21:13:24 +00:00
|
|
|
OutputDebugString(utf8_to_wide("\n" + debugMsg + "\n").c_str());
|
2024-01-19 00:55:55 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline void debugLog(const char* msg, const bool& isError = false, const std::string& filename = "", const int& line = 0)
|
2024-01-19 17:52:00 +00:00
|
|
|
{
|
2024-01-20 21:13:24 +00:00
|
|
|
debugLog(std::string(msg), isError, filename, line);
|
2024-01-19 17:52:00 +00:00
|
|
|
}
|
|
|
|
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline void debugLog(const std::wstring& msg, const bool& isError = false, const std::string& filename = "", const int& line = 0)
|
2024-01-19 00:55:55 +00:00
|
|
|
{
|
2024-01-20 21:13:24 +00:00
|
|
|
debugLog(wide_to_utf8(msg), isError, filename, line);
|
2024-01-19 00:55:55 +00:00
|
|
|
}
|
|
|
|
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline void debugLog(const bool& value, const bool& isError = false, const std::string& filename = "", const int& line = 0)
|
2024-01-19 17:52:00 +00:00
|
|
|
{
|
2024-01-20 21:13:24 +00:00
|
|
|
debugLog(value ? "true" : "false", isError, filename, line);
|
2024-01-19 17:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template<
|
|
|
|
typename T,
|
|
|
|
typename = typename std::enable_if<std::is_arithmetic<T>::value, T>::type
|
|
|
|
>
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline void debugLog(const T& value, const bool& isError = false, const std::string& filename = "", const int& line = 0)
|
2024-01-19 17:52:00 +00:00
|
|
|
{
|
|
|
|
debugLog(std::to_string(value), isError);
|
|
|
|
}
|
|
|
|
|
2024-01-19 00:55:55 +00:00
|
|
|
static inline std::string getHRMessage(const HRESULT& error)
|
|
|
|
{
|
2024-01-20 21:13:24 +00:00
|
|
|
return wide_to_utf8(_com_error(error).ErrorMessage());
|
2024-01-19 00:55:55 +00:00
|
|
|
}
|
|
|
|
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline void debugLog(const HRESULT& hr, const std::string& filename = "", const int& line = 0)
|
2024-01-19 00:55:55 +00:00
|
|
|
{
|
|
|
|
auto isError = hr != S_OK;
|
2024-01-23 15:01:09 +00:00
|
|
|
auto errorCode = std::to_string(hr);
|
|
|
|
debugLog((isError ? "Error " + errorCode + ": " : "Message: ") + getHRMessage(hr), isError, filename, line);
|
2024-01-19 00:55:55 +00:00
|
|
|
}
|
|
|
|
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline bool succeededOrLog(const HRESULT& hr, const std::string& filename = "", const int& line = 0)
|
2024-01-19 00:55:55 +00:00
|
|
|
{
|
|
|
|
if (SUCCEEDED(hr)) {
|
|
|
|
return true;
|
|
|
|
}
|
2024-01-20 21:13:24 +00:00
|
|
|
debugLog(hr, filename, line);
|
2024-01-19 00:55:55 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline bool failedAndLog(const HRESULT& hr, const std::string& filename = "", const int& line = 0)
|
2024-01-19 00:55:55 +00:00
|
|
|
{
|
|
|
|
if (FAILED(hr)) {
|
2024-01-20 21:13:24 +00:00
|
|
|
debugLog(hr, filename, line);
|
2024-01-19 00:55:55 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2024-01-20 21:13:24 +00:00
|
|
|
static inline void failedLog(const HRESULT& hr, const std::string& filename = "", const int& line = 0)
|
2024-01-19 00:55:55 +00:00
|
|
|
{
|
|
|
|
if (FAILED(hr)) {
|
2024-01-20 21:13:24 +00:00
|
|
|
debugLog(hr, filename, line);
|
2024-01-19 00:55:55 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-20 21:13:24 +00:00
|
|
|
#ifndef NDEBUG
|
|
|
|
#define debugLog(value) debugLog(value, false, __FILE__, __LINE__)
|
|
|
|
#define succeededOrLog(value) succeededOrLog(value, __FILE__, __LINE__)
|
|
|
|
#define failedAndLog(value) failedAndLog(value, __FILE__, __LINE__)
|
|
|
|
#define failedLog(value) failedLog(value, __FILE__, __LINE__)
|
|
|
|
#endif
|
|
|
|
|
2024-01-19 00:55:55 +00:00
|
|
|
#endif //FLUTTER_INAPPWEBVIEW_PLUGIN_LOG_UTIL_H_
|