diff options
| author | bunnei <bunneidev@gmail.com> | 2018-11-05 00:19:59 -0500 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-11-05 00:19:59 -0500 | 
| commit | e10483a8782db9ac4b2d1727b721f20dec4330c3 (patch) | |
| tree | e9757f8a9f85f7297a853f942d009b54307393cc | |
| parent | acdc770cfbb3001818ded53daf44588b3d5deaa8 (diff) | |
| parent | f5f6292810dab70bc9be0fa4d9f37fe2b5544d86 (diff) | |
Merge pull request #1441 from CarlKenner/DebuggerLog
logging: Add DebuggerBackend for logging to Visual Studio
| -rw-r--r-- | src/common/logging/backend.cpp | 11 | ||||
| -rw-r--r-- | src/common/logging/backend.h | 14 | ||||
| -rw-r--r-- | src/yuzu/main.cpp | 3 | ||||
| -rw-r--r-- | src/yuzu_cmd/yuzu.cpp | 3 | 
4 files changed, 29 insertions, 2 deletions
| diff --git a/src/common/logging/backend.cpp b/src/common/logging/backend.cpp index 6d5218465..5753b871a 100644 --- a/src/common/logging/backend.cpp +++ b/src/common/logging/backend.cpp @@ -12,7 +12,8 @@  #include <thread>  #include <vector>  #ifdef _WIN32 -#include <share.h> // For _SH_DENYWR +#include <share.h>   // For _SH_DENYWR +#include <windows.h> // For OutputDebugStringA  #else  #define _SH_DENYWR 0  #endif @@ -139,12 +140,18 @@ void FileBackend::Write(const Entry& entry) {      if (!file.IsOpen() || bytes_written > MAX_BYTES_WRITTEN) {          return;      } -    bytes_written += file.WriteString(FormatLogMessage(entry) + '\n'); +    bytes_written += file.WriteString(FormatLogMessage(entry).append(1, '\n'));      if (entry.log_level >= Level::Error) {          file.Flush();      }  } +void DebuggerBackend::Write(const Entry& entry) { +#ifdef _WIN32 +    ::OutputDebugStringA(FormatLogMessage(entry).append(1, '\n').c_str()); +#endif +} +  /// Macro listing all log classes. Code should define CLS and SUB as desired before invoking this.  #define ALL_LOG_CLASSES()                                                                          \      CLS(Log)                                                                                       \ diff --git a/src/common/logging/backend.h b/src/common/logging/backend.h index 11edbf1b6..91bb0c309 100644 --- a/src/common/logging/backend.h +++ b/src/common/logging/backend.h @@ -103,6 +103,20 @@ private:      std::size_t bytes_written;  }; +/** + * Backend that writes to Visual Studio's output window + */ +class DebuggerBackend : public Backend { +public: +    static const char* Name() { +        return "debugger"; +    } +    const char* GetName() const override { +        return Name(); +    } +    void Write(const Entry& entry) override; +}; +  void AddBackend(std::unique_ptr<Backend> backend);  void RemoveBackend(std::string_view backend_name); diff --git a/src/yuzu/main.cpp b/src/yuzu/main.cpp index ab423a1cf..74a44be37 100644 --- a/src/yuzu/main.cpp +++ b/src/yuzu/main.cpp @@ -142,6 +142,9 @@ static void InitializeLogging() {      const std::string& log_dir = FileUtil::GetUserPath(FileUtil::UserPath::LogDir);      FileUtil::CreateFullPath(log_dir);      Log::AddBackend(std::make_unique<Log::FileBackend>(log_dir + LOG_FILE)); +#ifdef _WIN32 +    Log::AddBackend(std::make_unique<Log::DebuggerBackend>()); +#endif  }  GMainWindow::GMainWindow() diff --git a/src/yuzu_cmd/yuzu.cpp b/src/yuzu_cmd/yuzu.cpp index c8b93b85b..806127b12 100644 --- a/src/yuzu_cmd/yuzu.cpp +++ b/src/yuzu_cmd/yuzu.cpp @@ -76,6 +76,9 @@ static void InitializeLogging() {      const std::string& log_dir = FileUtil::GetUserPath(FileUtil::UserPath::LogDir);      FileUtil::CreateFullPath(log_dir);      Log::AddBackend(std::make_unique<Log::FileBackend>(log_dir + LOG_FILE)); +#ifdef _WIN32 +    Log::AddBackend(std::make_unique<Log::DebuggerBackend>()); +#endif  }  /// Application entry point | 
