From f6c8842457184405348846fc7f9e1be67e83af7b Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Tue, 11 Dec 2018 23:58:46 +0100 Subject: [PATCH] move to debugging.[ch]pp --- components/CMakeLists.txt | 2 +- components/debug/debugging.cpp | 28 ++++++++++++++++++++++ components/debug/debugging.hpp | 7 +++--- components/debug/win32.cpp | 43 ---------------------------------- components/debug/win32.hpp | 9 ------- 5 files changed, 33 insertions(+), 56 deletions(-) delete mode 100644 components/debug/win32.cpp delete mode 100644 components/debug/win32.hpp diff --git a/components/CMakeLists.txt b/components/CMakeLists.txt index e34a95396..7a88dc18e 100644 --- a/components/CMakeLists.txt +++ b/components/CMakeLists.txt @@ -90,7 +90,7 @@ add_component_dir (misc ) add_component_dir (debug - debugging debuglog win32 + debugging debuglog ) IF(NOT WIN32 AND NOT APPLE) diff --git a/components/debug/debugging.cpp b/components/debug/debugging.cpp index caef1e1dc..7aa7a127a 100644 --- a/components/debug/debugging.cpp +++ b/components/debug/debugging.cpp @@ -4,6 +4,34 @@ namespace Debug { +#ifdef _WIN32 + bool attachParentConsole() + { + if (GetConsoleWindow() != nullptr) + return true; + + if (AttachConsole(ATTACH_PARENT_PROCESS)) + { + fflush(stdout); + fflush(stderr); + std::cout.flush(); + std::cerr.flush(); + + // this looks dubious but is really the right way + _wfreopen(L"CON", L"w", stdout); + _wfreopen(L"CON", L"w", stderr); + _wfreopen(L"CON", L"r", stdin); + freopen("CON", "w", stdout); + freopen("CON", "w", stderr); + freopen("CON", "r", stdin); + + return true; + } + + return false; + } +#endif + std::streamsize DebugOutputBase::write(const char *str, std::streamsize size) { // Skip debug level marker diff --git a/components/debug/debugging.hpp b/components/debug/debugging.hpp index 440e8fa47..bf9fbd38c 100644 --- a/components/debug/debugging.hpp +++ b/components/debug/debugging.hpp @@ -9,9 +9,6 @@ #include #include "debuglog.hpp" -#if defined _WIN32 -# include "win32.hpp" -#endif namespace Debug { @@ -46,6 +43,10 @@ namespace Debug } }; +#ifdef _WIN32 + bool attachParentConsole(); +#endif + #if defined(_WIN32) && defined(_DEBUG) #ifndef WIN32_LEAN_AND_MEAN #define WIN32_LEAN_AND_MEAN 1 diff --git a/components/debug/win32.cpp b/components/debug/win32.cpp deleted file mode 100644 index 16a264a0b..000000000 --- a/components/debug/win32.cpp +++ /dev/null @@ -1,43 +0,0 @@ -#ifdef _WIN32 - -#include "win32.hpp" - -#undef _CRT_SECURE_NO_WARNINGS -#define _CRT_SECURE_NO_WARNINGS - -#include -#include - -#include - -namespace Debug { - -bool attachParentConsole() -{ - if (GetConsoleWindow() != nullptr) - return true; - - if (AttachConsole(ATTACH_PARENT_PROCESS)) - { - fflush(stdout); - fflush(stderr); - std::cout.flush(); - std::cerr.flush(); - - // this looks dubious but is really the right way - _wfreopen(L"CON", L"w", stdout); - _wfreopen(L"CON", L"w", stderr); - _wfreopen(L"CON", L"r", stdin); - freopen("CON", "w", stdout); - freopen("CON", "w", stderr); - freopen("CON", "r", stdin); - - return true; - } - - return false; -} - -} // ns Debug - -#endif diff --git a/components/debug/win32.hpp b/components/debug/win32.hpp deleted file mode 100644 index d3c8d4094..000000000 --- a/components/debug/win32.hpp +++ /dev/null @@ -1,9 +0,0 @@ -#pragma once - -#ifdef _WIN32 - -namespace Debug { - bool attachParentConsole(); -} - -#endif