mirror of
https://github.com/microsoft/PowerToys.git
synced 2026-04-05 02:36:19 +02:00
[Setup] Add logging for registry changes + add logger for powerpreview
- cleanup logger project + remove SettingsAPI dependency
This commit is contained in:
committed by
Andrey Nekrasov
parent
d036740c8b
commit
bef119b03b
@@ -3,7 +3,7 @@
|
||||
#include "pch.h"
|
||||
#include "framework.h"
|
||||
#include "logger.h"
|
||||
#include <map>
|
||||
#include <unordered_map>
|
||||
#include <spdlog/sinks/daily_file_sink.h>
|
||||
#include <spdlog/sinks/msvc_sink.h>
|
||||
#include <spdlog/sinks/null_sink.h>
|
||||
@@ -16,26 +16,32 @@ using spdlog::sinks::daily_file_sink_mt;
|
||||
using spdlog::sinks::msvc_sink_mt;
|
||||
using std::make_shared;
|
||||
|
||||
std::map<std::wstring, level_enum> logLevelMapping = {
|
||||
{ L"trace", level_enum::trace },
|
||||
{ L"debug", level_enum::debug },
|
||||
{ L"info", level_enum::info },
|
||||
{ L"warn", level_enum::warn },
|
||||
{ L"err", level_enum::err },
|
||||
{ L"critical", level_enum::critical },
|
||||
{ L"off", level_enum::off },
|
||||
};
|
||||
namespace
|
||||
{
|
||||
const std::unordered_map<std::wstring, level_enum> logLevelMapping = {
|
||||
{ L"trace", level_enum::trace },
|
||||
{ L"debug", level_enum::debug },
|
||||
{ L"info", level_enum::info },
|
||||
{ L"warn", level_enum::warn },
|
||||
{ L"err", level_enum::err },
|
||||
{ L"critical", level_enum::critical },
|
||||
{ L"off", level_enum::off },
|
||||
};
|
||||
}
|
||||
|
||||
level_enum getLogLevel(std::wstring_view logSettingsPath)
|
||||
{
|
||||
auto logLevel = get_log_settings(logSettingsPath).logLevel;
|
||||
level_enum result = logLevelMapping[LogSettings::defaultLogLevel];
|
||||
if (logLevelMapping.find(logLevel) != logLevelMapping.end())
|
||||
if (auto it = logLevelMapping.find(logLevel); it != logLevelMapping.end())
|
||||
{
|
||||
result = logLevelMapping[logLevel];
|
||||
return it->second;
|
||||
}
|
||||
|
||||
return result;
|
||||
if (auto it = logLevelMapping.find(LogSettings::defaultLogLevel); it != logLevelMapping.end())
|
||||
{
|
||||
return it->second;
|
||||
}
|
||||
return level_enum::trace;
|
||||
}
|
||||
|
||||
std::shared_ptr<spdlog::logger> Logger::logger = spdlog::null_logger_mt("null");
|
||||
@@ -89,3 +95,14 @@ void Logger::init(std::string loggerName, std::wstring logFilePath, std::wstring
|
||||
spdlog::flush_every(std::chrono::seconds(3));
|
||||
logger->info("{} logger is initialized", loggerName);
|
||||
}
|
||||
|
||||
void Logger::init(std::vector<spdlog::sink_ptr> sinks)
|
||||
{
|
||||
auto logger = std::make_shared<spdlog::logger>("", begin(sinks), end(sinks));
|
||||
if (!logger)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
Logger::logger = logger;
|
||||
}
|
||||
|
||||
@@ -13,6 +13,7 @@ public:
|
||||
Logger() = delete;
|
||||
|
||||
static void init(std::string loggerName, std::wstring logFilePath, std::wstring_view logSettingsPath);
|
||||
static void init(std::vector<spdlog::sink_ptr> sinks);
|
||||
|
||||
// log message should not be localized
|
||||
template<typename FormatString, typename... Args>
|
||||
|
||||
@@ -52,9 +52,6 @@
|
||||
<ProjectReference Include="..\..\logging\logging.vcxproj">
|
||||
<Project>{7e1e3f13-2bd6-3f75-a6a7-873a2b55c60f}</Project>
|
||||
</ProjectReference>
|
||||
<ProjectReference Include="..\SettingsAPI\SetttingsAPI.vcxproj">
|
||||
<Project>{6955446d-23f7-4023-9bb3-8657f904af99}</Project>
|
||||
</ProjectReference>
|
||||
</ItemGroup>
|
||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||
<ImportGroup Label="ExtensionTargets">
|
||||
|
||||
@@ -9,7 +9,7 @@ using namespace winrt::Windows::Data::Json;
|
||||
|
||||
LogSettings::LogSettings()
|
||||
{
|
||||
this->logLevel = LogSettings::defaultLogLevel;
|
||||
logLevel = defaultLogLevel;
|
||||
}
|
||||
|
||||
std::optional<JsonObject> from_file(std::wstring_view file_name)
|
||||
|
||||
@@ -13,6 +13,8 @@ struct LogSettings
|
||||
inline const static std::wstring actionRunnerLogPath = L"RunnerLogs\\action-runner-log.txt";
|
||||
inline const static std::string updateLoggerName = "update";
|
||||
inline const static std::wstring updateLogPath = L"UpdateLogs\\update-log.txt";
|
||||
inline const static std::string fileExplorerLoggerName = "FileExplorer";
|
||||
inline const static std::wstring fileExplorerLogPath = L"Logs\\file-explorer-log.txt";
|
||||
inline const static std::string launcherLoggerName = "launcher";
|
||||
inline const static std::wstring launcherLogPath = L"LogsModuleInterface\\launcher-log.txt";
|
||||
inline const static std::wstring awakeLogPath = L"Logs\\awake-log.txt";
|
||||
|
||||
Reference in New Issue
Block a user