| 
									
										
										
										
											2019-04-11 14:40:54 +08:00
										 |  |  | // Copyright (c) 2016-2018 Kiwano - Nomango
 | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | // 
 | 
					
						
							|  |  |  | // Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
					
						
							|  |  |  | // of this software and associated documentation files (the "Software"), to deal
 | 
					
						
							|  |  |  | // in the Software without restriction, including without limitation the rights
 | 
					
						
							|  |  |  | // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
					
						
							|  |  |  | // copies of the Software, and to permit persons to whom the Software is
 | 
					
						
							|  |  |  | // furnished to do so, subject to the following conditions:
 | 
					
						
							|  |  |  | // 
 | 
					
						
							|  |  |  | // The above copyright notice and this permission notice shall be included in
 | 
					
						
							|  |  |  | // all copies or substantial portions of the Software.
 | 
					
						
							|  |  |  | // 
 | 
					
						
							|  |  |  | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
					
						
							|  |  |  | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
					
						
							|  |  |  | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
					
						
							|  |  |  | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
					
						
							|  |  |  | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
					
						
							|  |  |  | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
					
						
							|  |  |  | // THE SOFTWARE.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-14 21:52:49 +08:00
										 |  |  | #include "Logger.h"
 | 
					
						
							| 
									
										
										
										
											2019-03-31 13:08:59 +08:00
										 |  |  | #include <iostream>
 | 
					
						
							| 
									
										
										
										
											2019-04-24 13:33:19 +08:00
										 |  |  | #include <fstream>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	std::streambuf* cin_buffer, * cout_buffer, * cerr_buffer; | 
					
						
							|  |  |  | 	std::fstream console_input, console_output, console_error; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	std::wstreambuf* wcin_buffer, * wcout_buffer, * wcerr_buffer; | 
					
						
							|  |  |  | 	std::wfstream wconsole_input, wconsole_output, wconsole_error; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	void RedirectStdIO() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		cin_buffer = std::cin.rdbuf(); | 
					
						
							|  |  |  | 		cout_buffer = std::cout.rdbuf(); | 
					
						
							|  |  |  | 		cerr_buffer = std::cerr.rdbuf(); | 
					
						
							|  |  |  | 		wcin_buffer = std::wcin.rdbuf(); | 
					
						
							|  |  |  | 		wcout_buffer = std::wcout.rdbuf(); | 
					
						
							|  |  |  | 		wcerr_buffer = std::wcerr.rdbuf(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		console_input.open("CONIN$", std::ios::in); | 
					
						
							|  |  |  | 		console_output.open("CONOUT$", std::ios::out); | 
					
						
							|  |  |  | 		console_error.open("CONOUT$", std::ios::out); | 
					
						
							|  |  |  | 		wconsole_input.open("CONIN$", std::ios::in); | 
					
						
							|  |  |  | 		wconsole_output.open("CONOUT$", std::ios::out); | 
					
						
							|  |  |  | 		wconsole_error.open("CONOUT$", std::ios::out); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		FILE* dummy; | 
					
						
							|  |  |  | 		freopen_s(&dummy, "CONOUT$", "w+t", stdout); | 
					
						
							|  |  |  | 		freopen_s(&dummy, "CONIN$", "r+t", stdin); | 
					
						
							|  |  |  | 		freopen_s(&dummy, "CONOUT$", "w+t", stderr); | 
					
						
							|  |  |  | 		(void)dummy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		std::cin.rdbuf(console_input.rdbuf()); | 
					
						
							|  |  |  | 		std::cout.rdbuf(console_output.rdbuf()); | 
					
						
							|  |  |  | 		std::cerr.rdbuf(console_error.rdbuf()); | 
					
						
							|  |  |  | 		std::wcin.rdbuf(wconsole_input.rdbuf()); | 
					
						
							|  |  |  | 		std::wcout.rdbuf(wconsole_output.rdbuf()); | 
					
						
							|  |  |  | 		std::wcerr.rdbuf(wconsole_error.rdbuf()); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	void ResetStdIO() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		console_input.close(); | 
					
						
							|  |  |  | 		console_output.close(); | 
					
						
							|  |  |  | 		console_error.close(); | 
					
						
							|  |  |  | 		wconsole_input.close(); | 
					
						
							|  |  |  | 		wconsole_output.close(); | 
					
						
							|  |  |  | 		wconsole_error.close(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		std::cin.rdbuf(cin_buffer); | 
					
						
							|  |  |  | 		std::cout.rdbuf(cout_buffer); | 
					
						
							|  |  |  | 		std::cerr.rdbuf(cerr_buffer); | 
					
						
							|  |  |  | 		std::wcin.rdbuf(wcin_buffer); | 
					
						
							|  |  |  | 		std::wcout.rdbuf(wcout_buffer); | 
					
						
							|  |  |  | 		std::wcerr.rdbuf(wcerr_buffer); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		fclose(stdout); | 
					
						
							|  |  |  | 		fclose(stdin); | 
					
						
							|  |  |  | 		fclose(stderr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		cin_buffer = nullptr; | 
					
						
							|  |  |  | 		cout_buffer = nullptr; | 
					
						
							|  |  |  | 		cerr_buffer = nullptr; | 
					
						
							|  |  |  | 		wcin_buffer = nullptr; | 
					
						
							|  |  |  | 		wcout_buffer = nullptr; | 
					
						
							|  |  |  | 		wcerr_buffer = nullptr; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	HWND allocated_console = nullptr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	HWND AllocateConsole() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (::AllocConsole()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			allocated_console = ::GetConsoleWindow(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (allocated_console) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				RedirectStdIO(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return allocated_console; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	void FreeAllocatedConsole() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (allocated_console) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			ResetStdIO(); | 
					
						
							|  |  |  | 			::FreeConsole(); | 
					
						
							|  |  |  | 			allocated_console = nullptr; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	HWND GetAllocatedConsole() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return allocated_console; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-11 14:40:54 +08:00
										 |  |  | namespace kiwano | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 	namespace __console_colors | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		const WORD _blue = FOREGROUND_BLUE | FOREGROUND_INTENSITY; | 
					
						
							|  |  |  | 		const WORD _green = FOREGROUND_GREEN | FOREGROUND_INTENSITY; | 
					
						
							|  |  |  | 		const WORD _red = FOREGROUND_RED | FOREGROUND_INTENSITY; | 
					
						
							|  |  |  | 		const WORD _yellow = FOREGROUND_GREEN | FOREGROUND_RED | FOREGROUND_INTENSITY; | 
					
						
							|  |  |  | 		const WORD _white = FOREGROUND_BLUE | FOREGROUND_GREEN | FOREGROUND_RED | FOREGROUND_INTENSITY; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		const WORD _blue_bg = _white | BACKGROUND_BLUE | BACKGROUND_INTENSITY; | 
					
						
							|  |  |  | 		const WORD _green_bg = _white | BACKGROUND_GREEN | BACKGROUND_INTENSITY; | 
					
						
							|  |  |  | 		const WORD _red_bg = _white | BACKGROUND_RED | BACKGROUND_INTENSITY; | 
					
						
							|  |  |  | 		const WORD _yellow_bg = BACKGROUND_GREEN | BACKGROUND_RED | BACKGROUND_INTENSITY; | 
					
						
							|  |  |  | 		const WORD _white_bg = BACKGROUND_BLUE | BACKGROUND_GREEN | BACKGROUND_RED | BACKGROUND_INTENSITY; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		const WORD _reset = _white; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DECLARE_HANDLE_COLOR(NAME, HANDLE_NAME, COLOR)\
 | 
					
						
							|  |  |  | 	inline std::wostream& (NAME)(std::wostream& _out)\ | 
					
						
							|  |  |  | 		{ ::SetConsoleTextAttribute(::GetStdHandle(HANDLE_NAME), _##COLOR); return _out; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DECLARE_COLOR(COLOR) \
 | 
					
						
							|  |  |  | 	DECLARE_HANDLE_COLOR(stdout_##COLOR, STD_OUTPUT_HANDLE, COLOR)\ | 
					
						
							|  |  |  | 	DECLARE_HANDLE_COLOR(stderr_##COLOR, STD_ERROR_HANDLE, COLOR) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DECLARE_BG_COLOR(COLOR) \
 | 
					
						
							|  |  |  | 	DECLARE_HANDLE_COLOR(stdout_##COLOR##_bg, STD_OUTPUT_HANDLE, COLOR##_bg)\ | 
					
						
							|  |  |  | 	DECLARE_HANDLE_COLOR(stderr_##COLOR##_bg, STD_ERROR_HANDLE, COLOR##_bg) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		DECLARE_COLOR(red); | 
					
						
							|  |  |  | 		DECLARE_COLOR(green); | 
					
						
							|  |  |  | 		DECLARE_COLOR(yellow); | 
					
						
							|  |  |  | 		DECLARE_COLOR(blue); | 
					
						
							|  |  |  | 		DECLARE_COLOR(white); | 
					
						
							|  |  |  | 		DECLARE_COLOR(reset); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		DECLARE_BG_COLOR(red); | 
					
						
							|  |  |  | 		DECLARE_BG_COLOR(green); | 
					
						
							|  |  |  | 		DECLARE_BG_COLOR(yellow); | 
					
						
							|  |  |  | 		DECLARE_BG_COLOR(blue); | 
					
						
							|  |  |  | 		DECLARE_BG_COLOR(white); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef DECLARE_COLOR
 | 
					
						
							|  |  |  | #undef DECLARE_BG_COLOR
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Logger::Logger() | 
					
						
							| 
									
										
										
										
											2019-03-31 13:08:59 +08:00
										 |  |  | 		: enabled_(true) | 
					
						
							|  |  |  | 		, default_stdout_color_(0) | 
					
						
							|  |  |  | 		, default_stderr_color_(0) | 
					
						
							|  |  |  | 		, output_stream_(std::wcout.rdbuf()) | 
					
						
							|  |  |  | 		, error_stream_(std::wcerr.rdbuf()) | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2019-03-31 13:08:59 +08:00
										 |  |  | 		ResetOutputStream(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-24 13:33:19 +08:00
										 |  |  | 	Logger::~Logger() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		FreeAllocatedConsole(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-31 13:08:59 +08:00
										 |  |  | 	void Logger::ResetOutputStream() | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2019-04-22 13:21:12 +08:00
										 |  |  | 		bool has_console = ::GetConsoleWindow() != nullptr; | 
					
						
							|  |  |  | 		if (has_console) | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2019-03-31 13:08:59 +08:00
										 |  |  | 			default_stdout_color_ = default_stderr_color_ = FOREGROUND_BLUE | FOREGROUND_GREEN | FOREGROUND_RED | FOREGROUND_INTENSITY; | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-31 13:08:59 +08:00
										 |  |  | 			CONSOLE_SCREEN_BUFFER_INFO stdout_info; | 
					
						
							|  |  |  | 			if (::GetConsoleScreenBufferInfo(::GetStdHandle(STD_OUTPUT_HANDLE), &stdout_info)) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				default_stdout_color_ = stdout_info.wAttributes; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			CONSOLE_SCREEN_BUFFER_INFO stderr_info; | 
					
						
							|  |  |  | 			if (::GetConsoleScreenBufferInfo(::GetStdHandle(STD_ERROR_HANDLE), &stderr_info)) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				default_stderr_color_ = stderr_info.wAttributes; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			RedirectOutputStreamBuffer(std::wcout.rdbuf()); | 
					
						
							|  |  |  | 			RedirectErrorStreamBuffer(std::wcerr.rdbuf()); | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-31 13:08:59 +08:00
										 |  |  | 	std::wstreambuf* Logger::RedirectOutputStreamBuffer(std::wstreambuf* buf) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return output_stream_.rdbuf(buf); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	std::wstreambuf* Logger::RedirectErrorStreamBuffer(std::wstreambuf* buf) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return error_stream_.rdbuf(buf); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-29 22:23:13 +08:00
										 |  |  | 	void Logger::Printf(const wchar_t* format, ...) | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		va_list args = nullptr; | 
					
						
							|  |  |  | 		va_start(args, format); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		Outputf(output_stream_, Logger::DefaultOutputColor, nullptr, format, args); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		va_end(args); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-29 22:23:13 +08:00
										 |  |  | 	void Logger::Messagef(const wchar_t* format, ...) | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		using namespace __console_colors; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		va_list args = nullptr; | 
					
						
							|  |  |  | 		va_start(args, format); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		Outputf(output_stream_, stdout_blue, nullptr, format, args); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		va_end(args); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-29 22:23:13 +08:00
										 |  |  | 	void Logger::Warningf(const wchar_t* format, ...) | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		using namespace __console_colors; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		va_list args = nullptr; | 
					
						
							|  |  |  | 		va_start(args, format); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		Outputf(output_stream_, stdout_yellow_bg, L" Warning:", format, args); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		va_end(args); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-29 22:23:13 +08:00
										 |  |  | 	void Logger::Errorf(const wchar_t* format, ...) | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		using namespace __console_colors; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		va_list args = nullptr; | 
					
						
							|  |  |  | 		va_start(args, format); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		Outputf(error_stream_, stderr_red_bg, L" Error:", format, args); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		va_end(args); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-29 22:23:13 +08:00
										 |  |  | 	void Logger::Outputf(std::wostream& os, std::wostream& (*color)(std::wostream&), const wchar_t* prompt, const wchar_t* format, va_list args) const | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2019-04-22 13:21:12 +08:00
										 |  |  | 		if (enabled_) | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2019-04-08 14:15:27 +08:00
										 |  |  | 			std::wstring output = MakeOutputStringf(prompt, format, args); | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-08 14:15:27 +08:00
										 |  |  | 			os << color << output << std::flush; | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 			::OutputDebugStringW(output.c_str()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			ResetConsoleColor(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-29 22:23:13 +08:00
										 |  |  | 	std::wstring Logger::MakeOutputStringf(const wchar_t* prompt, const wchar_t* format, va_list args) const | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2019-09-29 22:23:13 +08:00
										 |  |  | 		static wchar_t temp_buffer[1024 * 3 + 1]; | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-20 14:55:36 +08:00
										 |  |  | 		StringStream ss; | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 		ss << Logger::OutPrefix; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (prompt) | 
					
						
							|  |  |  | 			ss << prompt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (format) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			const auto len = ::_vscwprintf(format, args) + 1; | 
					
						
							|  |  |  | 			::_vsnwprintf_s(temp_buffer, len, len, format, args); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			ss << ' ' << temp_buffer; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return ss.str(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	std::wostream& Logger::OutPrefix(std::wostream& out) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		std::time_t unix = std::time(nullptr); | 
					
						
							|  |  |  | 		std::tm tmbuf; | 
					
						
							|  |  |  | 		localtime_s(&tmbuf, &unix); | 
					
						
							| 
									
										
										
										
											2019-04-11 14:40:54 +08:00
										 |  |  | 		out << std::put_time(&tmbuf, L"[kiwano] %H:%M:%S"); | 
					
						
							| 
									
										
										
										
											2019-04-08 04:01:52 +08:00
										 |  |  | 		return out; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-24 13:33:19 +08:00
										 |  |  | 	void Logger::ShowConsole(bool show) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		HWND current_console = ::GetConsoleWindow(); | 
					
						
							|  |  |  | 		if (show) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if (current_console) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				::ShowWindow(current_console, SW_SHOW); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				HWND console = ::AllocateConsole(); | 
					
						
							|  |  |  | 				if (!console) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					KGE_WARNING_LOG(L"AllocConsole failed"); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					// disable the close button of console
 | 
					
						
							|  |  |  | 					HMENU hmenu = ::GetSystemMenu(console, FALSE); | 
					
						
							|  |  |  | 					::RemoveMenu(hmenu, SC_CLOSE, MF_BYCOMMAND); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if (current_console) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (current_console == GetAllocatedConsole()) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					FreeAllocatedConsole(); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					::ShowWindow(current_console, SW_HIDE); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		ResetOutputStream(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-31 01:37:06 +08:00
										 |  |  | } |