📄 msg.cpp
字号:
/*
* $Id: msg.cpp,v 1.4 2006/11/21 11:34:55 vfrolov Exp $
*
* Copyright (c) 2006 Vyacheslav Frolov
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
*
* $Log: msg.cpp,v $
* Revision 1.4 2006/11/21 11:34:55 vfrolov
* Added
* ConsoleWrite()
* IsConsoleOpen()
* SetOutputFile()
* GetOutputFile()
*
* Revision 1.3 2006/10/23 12:04:23 vfrolov
* Added SetTitle()
*
* Revision 1.2 2006/10/17 10:03:59 vfrolov
* Added MB_SETFOREGROUND flag to MessageBox()
*
* Revision 1.1 2006/07/28 12:16:42 vfrolov
* Initial revision
*
*/
#include "precomp.h"
#include "msg.h"
#include "utils.h"
char *pOutputFile = NULL;
char title[80] = "";
///////////////////////////////////////////////////////////////
static int ShowMsgDefault(LPCSTR pText, UINT type)
{
return MessageBox(NULL, pText, title, type|MB_SETFOREGROUND);
}
static int (* pShowMsg)(LPCSTR pText, UINT type) = ShowMsgDefault;
///////////////////////////////////////////////////////////////
static BOOL isConsoleOpen = FALSE;
static void ConsoleWriteReadDefault(LPSTR pReadBuf, DWORD lenReadBuf, LPCSTR pText)
{
static HANDLE handle = INVALID_HANDLE_VALUE;
if (handle == INVALID_HANDLE_VALUE) {
AllocConsole();
handle = GetStdHandle(STD_OUTPUT_HANDLE);
SetConsoleTitle(title);
isConsoleOpen = TRUE;
}
if (pText)
WriteConsole(handle, pText, lstrlen(pText), NULL, NULL);
if (pReadBuf && lenReadBuf > 0) {
if (lenReadBuf > 1 &&
ReadConsole(GetStdHandle(STD_INPUT_HANDLE), pReadBuf, lenReadBuf - 1, &lenReadBuf, 0))
{
pReadBuf[lenReadBuf] = 0;
} else {
pReadBuf[0] = 0;
}
}
}
static void (* pConsole)(LPSTR pReadBuf, DWORD lenReadBuf, LPCSTR pText) = ConsoleWriteReadDefault;
///////////////////////////////////////////////////////////////
static void TraceDefault(LPCSTR pText)
{
pConsole(NULL, 0, pText);
if (!pOutputFile || !pText)
return;
HANDLE hFile = CreateFile(
pOutputFile,
GENERIC_WRITE,
FILE_SHARE_READ,
NULL,
OPEN_ALWAYS,
FILE_ATTRIBUTE_NORMAL,
NULL);
if (hFile != INVALID_HANDLE_VALUE) {
SetFilePointer(hFile, 0, NULL, FILE_END);
LPCSTR p;
for (p = pText ; *p ; p++) {
DWORD not_used;
if (*p == '\n')
WriteFile(hFile, "\r", sizeof(*p), ¬_used, NULL);
WriteFile(hFile, p, sizeof(*p), ¬_used, NULL);
}
CloseHandle(hFile);
}
}
static void (* pTrace)(LPCSTR pText) = TraceDefault;
///////////////////////////////////////////////////////////////
static int ShowMsgVA(UINT type, const char *pFmt, va_list va)
{
char buf[1024];
VSNPRINTF(buf, sizeof(buf)/sizeof(buf[0]), pFmt, va);
return pShowMsg(buf, type);
}
///////////////////////////////////////////////////////////////
static int ShowErrorVA(UINT type, DWORD err, const char *pFmt, va_list va)
{
char buf[1024];
VSNPRINTF(buf, sizeof(buf)/sizeof(buf[0]), pFmt, va);
LPVOID pMsgBuf;
FormatMessage(
FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
err,
MAKELANGID(LANG_NEUTRAL, SUBLANG_NEUTRAL),
(LPTSTR) &pMsgBuf,
0,
NULL);
int len = lstrlen(buf);
SNPRINTF(buf + len, sizeof(buf)/sizeof(buf[0]) - len, "\nERROR: 0x%08lX - %s\n", (unsigned long)err, pMsgBuf);
LocalFree(pMsgBuf);
return pShowMsg(buf, type);
}
///////////////////////////////////////////////////////////////
int ShowMsg(UINT type, const char *pFmt, ...)
{
int res;
va_list va;
va_start(va, pFmt);
res = ShowMsgVA(type, pFmt, va);
va_end(va);
return res;
}
///////////////////////////////////////////////////////////////
int ShowError(UINT type, DWORD err, const char *pFmt, ...)
{
int res;
va_list va;
va_start(va, pFmt);
res = ShowErrorVA(type, err, pFmt, va);
va_end(va);
return res;
}
///////////////////////////////////////////////////////////////
int ShowLastError(UINT type, const char *pFmt, ...)
{
int res;
DWORD err = GetLastError();
va_list va;
va_start(va, pFmt);
res = ShowErrorVA(type, err, pFmt, va);
va_end(va);
SetLastError(err);
return res;
}
///////////////////////////////////////////////////////////////
void Trace(const char *pFmt, ...)
{
char buf[1024];
va_list va;
va_start(va, pFmt);
VSNPRINTF(buf, sizeof(buf)/sizeof(buf[0]), pFmt, va);
va_end(va);
pTrace(buf);
}
///////////////////////////////////////////////////////////////
void ConsoleWriteRead(char *pReadBuf, int lenReadBuf, const char *pFmt, ...)
{
char buf[1024];
va_list va;
va_start(va, pFmt);
VSNPRINTF(buf, sizeof(buf)/sizeof(buf[0]), pFmt, va);
va_end(va);
pConsole(pReadBuf, lenReadBuf, buf);
}
///////////////////////////////////////////////////////////////
void ConsoleWrite(const char *pFmt, ...)
{
char buf[1024];
va_list va;
va_start(va, pFmt);
VSNPRINTF(buf, sizeof(buf)/sizeof(buf[0]), pFmt, va);
va_end(va);
pConsole(NULL, 0, buf);
}
///////////////////////////////////////////////////////////////
BOOL IsConsoleOpen()
{
return isConsoleOpen;
}
///////////////////////////////////////////////////////////////
void SetTitle(const char *pTitle)
{
lstrcpyn(title, pTitle, sizeof(title)/sizeof(title[0]));
}
///////////////////////////////////////////////////////////////
void SetOutputFile(const char *pFile)
{
if (pOutputFile) {
LocalFree(pOutputFile);
pOutputFile = NULL;
}
if (pFile) {
pOutputFile = (char *)LocalAlloc(LPTR, (lstrlen(pFile) + 1)*sizeof(*pFile));
if (pOutputFile)
lstrcpy(pOutputFile, pFile);
}
}
///////////////////////////////////////////////////////////////
const char *GetOutputFile()
{
return pOutputFile;
}
///////////////////////////////////////////////////////////////
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -