1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-16 19:19:56 +00:00

enable win32 debug console when launching from console

This commit is contained in:
Stanislaw Halik 2018-12-08 01:29:14 +01:00
parent d791dcfbf3
commit 64e960aa22
5 changed files with 70 additions and 1 deletions

View file

@ -90,7 +90,7 @@ add_component_dir (misc
)
add_component_dir (debug
debugging debuglog
debugging debuglog win32
)
IF(NOT WIN32 AND NOT APPLE)

View file

@ -52,6 +52,11 @@ namespace Debug
int wrapApplication(int (*innerApplication)(int argc, char *argv[]), int argc, char *argv[], const std::string& appName)
{
#if defined _WIN32
// grab a console window if we don't have one
(void)Debug::attachParentConsole();
#endif
// Some objects used to redirect cout and cerr
// Scope must be here, so this still works inside the catch block for logging exceptions
std::streambuf* cout_rdbuf = std::cout.rdbuf ();

View file

@ -9,6 +9,9 @@
#include <SDL_messagebox.h>
#include "debuglog.hpp"
#if defined _WIN32
# include "win32.hpp"
#endif
namespace Debug
{

View file

@ -0,0 +1,56 @@
#include "win32.hpp"
#undef _CRT_SECURE_NO_WARNINGS
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <cstdio>
#include <windows.h>
namespace Debug {
bool attachParentConsole()
{
// we already have a console window
if (GetConsoleWindow() != nullptr)
return true;
// our parent window has a console we can use
if (AttachConsole(ATTACH_PARENT_PROCESS))
{
// start with consistent state
fflush(stdin);
fflush(stderr);
std::cout.flush();
std::cerr.flush();
// fix fprintf(3) and fwprintf(3)
// this looks strange, but nothing is ever simple on Windows.
_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", "w", stderr);
// it can be verified that input/output works as expected.
#if 0
fprintf(stdout, "ascii stdout\n");
fwprintf(stdout, L"wide stdout\n");
fprintf(stderr, "ascii stderr\n");
fwprintf(stderr, L"wide stderr\n");
std::cout << "ascii cout\n";
std::cout << L"wide cout\n";
std::cerr << "ascii cerr\n";
std::cerr << L"wide cerr\n";
#endif
return true;
}
return false;
}
} // ns Debug

View file

@ -0,0 +1,5 @@
#pragma once
namespace Debug {
bool attachParentConsole();
}