2007-11-10 22:00:00 +01:00
|
|
|
|
//=======================================================================
|
|
|
|
|
// Copyright XashXT Group 2007 <20>
|
|
|
|
|
// console.c - win and dos console
|
|
|
|
|
//=======================================================================
|
|
|
|
|
|
|
|
|
|
#include "launch.h"
|
|
|
|
|
|
|
|
|
|
HINSTANCE base_hInstance;
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
===============================================================================
|
|
|
|
|
|
|
|
|
|
WIN32 CONSOLE
|
|
|
|
|
|
|
|
|
|
===============================================================================
|
|
|
|
|
*/
|
|
|
|
|
|
2009-01-13 22:00:00 +01:00
|
|
|
|
// console defines
|
2007-11-10 22:00:00 +01:00
|
|
|
|
#define SUBMIT_ID 1 // "submit" button
|
2009-01-13 22:00:00 +01:00
|
|
|
|
#define QUIT_ON_ESCAPE_ID 2 // escape event
|
2007-11-11 22:00:00 +01:00
|
|
|
|
#define EDIT_ID 110
|
|
|
|
|
#define INPUT_ID 109
|
2007-11-10 22:00:00 +01:00
|
|
|
|
#define IDI_ICON1 101
|
2010-02-18 22:00:00 +01:00
|
|
|
|
|
2007-11-10 22:00:00 +01:00
|
|
|
|
#define SYSCONSOLE "SystemConsole"
|
2010-02-18 22:00:00 +01:00
|
|
|
|
#define COMMAND_HISTORY 64 // system console keep more commands than game console
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
HWND hWnd;
|
|
|
|
|
HWND hwndBuffer;
|
|
|
|
|
HWND hwndButtonSubmit;
|
|
|
|
|
HBRUSH hbrEditBackground;
|
|
|
|
|
HFONT hfBufferFont;
|
|
|
|
|
HFONT hfButtonFont;
|
|
|
|
|
HWND hwndInputLine;
|
2010-02-18 22:00:00 +01:00
|
|
|
|
string consoleText;
|
|
|
|
|
string returnedText;
|
|
|
|
|
string historyLines[COMMAND_HISTORY];
|
|
|
|
|
int nextHistoryLine;
|
|
|
|
|
int historyLine;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
int status;
|
|
|
|
|
int windowWidth, windowHeight;
|
|
|
|
|
WNDPROC SysInputLineWndProc;
|
2009-09-10 22:00:00 +02:00
|
|
|
|
size_t outLen;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
} WinConData;
|
|
|
|
|
static WinConData s_wcd;
|
|
|
|
|
|
|
|
|
|
void Con_ShowConsole( bool show )
|
|
|
|
|
{
|
2007-11-11 22:00:00 +01:00
|
|
|
|
if( !s_wcd.hWnd || Sys.hooked_out )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
return;
|
|
|
|
|
if ( show == s_wcd.status )
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
s_wcd.status = show;
|
|
|
|
|
if( show )
|
|
|
|
|
{
|
|
|
|
|
ShowWindow( s_wcd.hWnd, SW_SHOWNORMAL );
|
|
|
|
|
SendMessage( s_wcd.hwndBuffer, EM_LINESCROLL, 0, 0xffff );
|
|
|
|
|
}
|
|
|
|
|
else ShowWindow( s_wcd.hWnd, SW_HIDE );
|
|
|
|
|
}
|
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
void Con_DisableInput( void )
|
|
|
|
|
{
|
|
|
|
|
if( Sys.con_readonly ) return;
|
|
|
|
|
SendMessage( s_wcd.hwndButtonSubmit, WM_ENABLE, 0, 0 );
|
|
|
|
|
SendMessage( s_wcd.hwndInputLine, WM_ENABLE, 0, 0 );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void Con_SetInputText( const char *inputText )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( Sys.con_readonly ) return;
|
|
|
|
|
|
|
|
|
|
SetWindowText( s_wcd.hwndInputLine, inputText );
|
|
|
|
|
SendMessage( s_wcd.hwndInputLine, EM_SETSEL, com_strlen( inputText ), -1 );
|
|
|
|
|
}
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2010-07-24 22:00:00 +02:00
|
|
|
|
static int Con_KeyEvent( int key, bool down )
|
|
|
|
|
{
|
|
|
|
|
char inputBuffer[1024];
|
|
|
|
|
|
|
|
|
|
if( !down )
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
switch( key )
|
|
|
|
|
{
|
|
|
|
|
case VK_TAB:
|
|
|
|
|
GetWindowText( s_wcd.hwndInputLine, inputBuffer, sizeof( inputBuffer ));
|
|
|
|
|
if( Sys.CmdAuto ) Sys.CmdAuto( inputBuffer );
|
|
|
|
|
Con_SetInputText( inputBuffer );
|
|
|
|
|
return 1;
|
|
|
|
|
case VK_DOWN:
|
|
|
|
|
if( s_wcd.historyLine == s_wcd.nextHistoryLine )
|
|
|
|
|
return 0;
|
|
|
|
|
s_wcd.historyLine++;
|
|
|
|
|
Con_SetInputText( s_wcd.historyLines[s_wcd.historyLine % COMMAND_HISTORY] );
|
|
|
|
|
return 1;
|
|
|
|
|
case VK_UP:
|
|
|
|
|
if( s_wcd.nextHistoryLine - s_wcd.historyLine < COMMAND_HISTORY && s_wcd.historyLine > 0 )
|
|
|
|
|
s_wcd.historyLine--;
|
|
|
|
|
Con_SetInputText( s_wcd.historyLines[s_wcd.historyLine % COMMAND_HISTORY] );
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
static long _stdcall Con_WndProc( HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
|
|
|
|
{
|
|
|
|
|
switch( uMsg )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
case WM_ACTIVATE:
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( LOWORD( wParam ) != WA_INACTIVE )
|
|
|
|
|
SetFocus( s_wcd.hwndInputLine );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
break;
|
|
|
|
|
case WM_CLOSE:
|
2008-06-05 22:00:00 +02:00
|
|
|
|
if( Sys.app_state == SYS_ERROR )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
// send windows message
|
|
|
|
|
PostQuitMessage( 0 );
|
|
|
|
|
}
|
2010-02-18 22:00:00 +01:00
|
|
|
|
else Sys_Exit(); // otherwise
|
2007-11-10 22:00:00 +01:00
|
|
|
|
return 0;
|
|
|
|
|
case WM_CTLCOLORSTATIC:
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( (HWND)lParam == s_wcd.hwndBuffer )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
SetBkColor( (HDC)wParam, RGB( 0x90, 0x90, 0x90 ));
|
|
|
|
|
SetTextColor( (HDC)wParam, RGB( 0xff, 0xff, 0xff ));
|
|
|
|
|
return (long)s_wcd.hbrEditBackground;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case WM_COMMAND:
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( wParam == SUBMIT_ID )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
SendMessage( s_wcd.hwndInputLine, WM_CHAR, 13, 0L );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
SetFocus( s_wcd.hwndInputLine );
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case WM_HOTKEY:
|
2010-02-18 22:00:00 +01:00
|
|
|
|
switch( LOWORD( wParam ))
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2009-01-13 22:00:00 +01:00
|
|
|
|
case QUIT_ON_ESCAPE_ID:
|
2007-11-10 22:00:00 +01:00
|
|
|
|
PostQuitMessage( 0 );
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case WM_CREATE:
|
2010-02-18 22:00:00 +01:00
|
|
|
|
s_wcd.hbrEditBackground = CreateSolidBrush( RGB( 0x90, 0x90, 0x90 ));
|
2007-11-10 22:00:00 +01:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
return DefWindowProc( hWnd, uMsg, wParam, lParam );
|
|
|
|
|
}
|
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
long _stdcall Con_InputLineProc( HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
char inputBuffer[1024];
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
switch( uMsg )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
case WM_KILLFOCUS:
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if(( HWND )wParam == s_wcd.hWnd )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
SetFocus( hWnd );
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
break;
|
2010-07-24 22:00:00 +02:00
|
|
|
|
case WM_SYSKEYDOWN:
|
|
|
|
|
case WM_KEYDOWN:
|
|
|
|
|
if( Con_KeyEvent( LOWORD( wParam ), true ))
|
2010-02-18 22:00:00 +01:00
|
|
|
|
return 0;
|
2010-07-24 22:00:00 +02:00
|
|
|
|
break;
|
|
|
|
|
case WM_SYSKEYUP:
|
|
|
|
|
case WM_KEYUP:
|
|
|
|
|
if( Con_KeyEvent( LOWORD( wParam ), false ))
|
2010-02-18 22:00:00 +01:00
|
|
|
|
return 0;
|
|
|
|
|
break;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
case WM_CHAR:
|
2010-07-24 22:00:00 +02:00
|
|
|
|
if( Con_KeyEvent( wParam, true ))
|
|
|
|
|
return 0;
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( wParam == 13 && Sys.app_state != SYS_ERROR )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
GetWindowText( s_wcd.hwndInputLine, inputBuffer, sizeof( inputBuffer ));
|
2007-11-10 22:00:00 +01:00
|
|
|
|
com_strncat( s_wcd.consoleText, inputBuffer, sizeof( s_wcd.consoleText ) - com_strlen( s_wcd.consoleText ) - 5 );
|
|
|
|
|
com_strcat( s_wcd.consoleText, "\n" );
|
|
|
|
|
SetWindowText( s_wcd.hwndInputLine, "" );
|
2010-02-18 22:00:00 +01:00
|
|
|
|
Msg( ">%s\n", inputBuffer );
|
|
|
|
|
|
|
|
|
|
// copy line to history buffer
|
|
|
|
|
com_strncpy( s_wcd.historyLines[s_wcd.nextHistoryLine % COMMAND_HISTORY], inputBuffer, MAX_STRING );
|
|
|
|
|
s_wcd.nextHistoryLine++;
|
|
|
|
|
s_wcd.historyLine = s_wcd.nextHistoryLine;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
2010-07-24 22:00:00 +02:00
|
|
|
|
break;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
}
|
|
|
|
|
return CallWindowProc( s_wcd.SysInputLineWndProc, hWnd, uMsg, wParam, lParam );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
===============================================================================
|
|
|
|
|
|
|
|
|
|
WIN32 IO
|
|
|
|
|
|
|
|
|
|
===============================================================================
|
|
|
|
|
*/
|
|
|
|
|
/*
|
|
|
|
|
================
|
|
|
|
|
Con_PrintA
|
|
|
|
|
|
|
|
|
|
print into cmd32 console
|
|
|
|
|
================
|
|
|
|
|
*/
|
2010-02-18 22:00:00 +01:00
|
|
|
|
void Con_PrintA( const char *pMsg )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
DWORD cbWritten;
|
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
WriteFile( GetStdHandle( STD_OUTPUT_HANDLE ), pMsg, com_strlen( pMsg ), &cbWritten, 0 );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
================
|
|
|
|
|
Con_PrintW
|
|
|
|
|
|
|
|
|
|
print into window console
|
|
|
|
|
================
|
|
|
|
|
*/
|
2009-09-10 22:00:00 +02:00
|
|
|
|
void Con_PrintW( const char *pMsg )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2009-09-10 22:00:00 +02:00
|
|
|
|
size_t len = com.strlen( pMsg );
|
|
|
|
|
|
2007-11-10 22:00:00 +01:00
|
|
|
|
// replace selection instead of appending if we're overflowing
|
2009-09-10 22:00:00 +02:00
|
|
|
|
s_wcd.outLen += len;
|
|
|
|
|
if( s_wcd.outLen >= 0x7fff )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
SendMessage( s_wcd.hwndBuffer, EM_SETSEL, 0, -1 );
|
2009-09-10 22:00:00 +02:00
|
|
|
|
s_wcd.outLen = len;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
}
|
|
|
|
|
|
2009-09-10 22:00:00 +02:00
|
|
|
|
SendMessage( s_wcd.hwndBuffer, EM_REPLACESEL, 0, (LPARAM)pMsg );
|
|
|
|
|
|
2007-11-10 22:00:00 +01:00
|
|
|
|
// put this text into the windows console
|
|
|
|
|
SendMessage( s_wcd.hwndBuffer, EM_LINESCROLL, 0, 0xffff );
|
|
|
|
|
SendMessage( s_wcd.hwndBuffer, EM_SCROLLCARET, 0, 0 );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
================
|
|
|
|
|
Con_CreateConsole
|
|
|
|
|
|
|
|
|
|
create win32 console
|
|
|
|
|
================
|
|
|
|
|
*/
|
|
|
|
|
void Con_CreateConsole( void )
|
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
HDC hDC;
|
|
|
|
|
WNDCLASS wc;
|
|
|
|
|
RECT rect;
|
2008-10-27 22:00:00 +01:00
|
|
|
|
int nHeight;
|
|
|
|
|
int swidth, sheight, fontsize;
|
|
|
|
|
string Title, FontName;
|
|
|
|
|
int DEDSTYLE = WS_POPUPWINDOW | WS_CAPTION;
|
|
|
|
|
int CONSTYLE = WS_CHILD|WS_VISIBLE|WS_VSCROLL|WS_BORDER|WS_EX_CLIENTEDGE|ES_LEFT|ES_MULTILINE|ES_AUTOVSCROLL|ES_READONLY;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( Sys.con_silentmode )
|
|
|
|
|
return;
|
|
|
|
|
|
2007-11-14 22:00:00 +01:00
|
|
|
|
Sys_InitLog();
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2008-08-04 22:00:00 +02:00
|
|
|
|
if( Sys.hooked_out )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
// just init log
|
2007-11-11 22:00:00 +01:00
|
|
|
|
Sys.Con_Print = Con_PrintA;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
return;
|
|
|
|
|
}
|
2007-11-11 22:00:00 +01:00
|
|
|
|
Sys.Con_Print = Con_PrintW;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2008-10-27 22:00:00 +01:00
|
|
|
|
Mem_Set( &wc, 0, sizeof( wc ));
|
2007-11-10 22:00:00 +01:00
|
|
|
|
wc.style = 0;
|
|
|
|
|
wc.lpfnWndProc = (WNDPROC)Con_WndProc;
|
|
|
|
|
wc.cbClsExtra = 0;
|
|
|
|
|
wc.cbWndExtra = 0;
|
2007-11-11 22:00:00 +01:00
|
|
|
|
wc.hInstance = Sys.hInstance;
|
2008-08-04 22:00:00 +02:00
|
|
|
|
wc.hIcon = LoadIcon( Sys.hInstance, MAKEINTRESOURCE( IDI_ICON1 ));
|
|
|
|
|
wc.hCursor = LoadCursor( NULL, IDC_ARROW );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
wc.hbrBackground = (void *)COLOR_3DSHADOW;
|
|
|
|
|
wc.lpszClassName = SYSCONSOLE;
|
2010-07-21 22:00:00 +02:00
|
|
|
|
wc.lpszMenuName = 0;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2008-08-04 22:00:00 +02:00
|
|
|
|
if(!RegisterClass( &wc ))
|
2007-11-14 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
// print into log
|
2008-08-04 22:00:00 +02:00
|
|
|
|
MsgDev( D_WARN, "Can't register window class '%s'\n", SYSCONSOLE );
|
2007-11-14 22:00:00 +01:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2008-08-04 22:00:00 +02:00
|
|
|
|
if( Sys.con_showcredits )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
CONSTYLE &= ~WS_VSCROLL;
|
|
|
|
|
rect.left = 0;
|
|
|
|
|
rect.right = 536;
|
|
|
|
|
rect.top = 0;
|
|
|
|
|
rect.bottom = 280;
|
2008-10-27 22:00:00 +01:00
|
|
|
|
com.strncpy( FontName, "Arial", MAX_STRING );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
fontsize = 16;
|
|
|
|
|
}
|
2008-08-04 22:00:00 +02:00
|
|
|
|
else if( Sys.con_readonly )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
rect.left = 0;
|
|
|
|
|
rect.right = 536;
|
|
|
|
|
rect.top = 0;
|
|
|
|
|
rect.bottom = 364;
|
2008-10-27 22:00:00 +01:00
|
|
|
|
com.strncpy( FontName, "Fixedsys", MAX_STRING );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
fontsize = 8;
|
|
|
|
|
}
|
|
|
|
|
else // dedicated console
|
|
|
|
|
{
|
|
|
|
|
rect.left = 0;
|
2010-02-18 22:00:00 +01:00
|
|
|
|
rect.right = 640;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
rect.top = 0;
|
|
|
|
|
rect.bottom = 392;
|
2008-10-27 22:00:00 +01:00
|
|
|
|
com.strncpy( FontName, "System", MAX_STRING );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
fontsize = 14;
|
|
|
|
|
}
|
|
|
|
|
|
2008-10-27 22:00:00 +01:00
|
|
|
|
com.strncpy( Title, Sys.caption, MAX_STRING );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
AdjustWindowRect( &rect, DEDSTYLE, FALSE );
|
|
|
|
|
|
|
|
|
|
hDC = GetDC( GetDesktopWindow() );
|
|
|
|
|
swidth = GetDeviceCaps( hDC, HORZRES );
|
|
|
|
|
sheight = GetDeviceCaps( hDC, VERTRES );
|
|
|
|
|
ReleaseDC( GetDesktopWindow(), hDC );
|
|
|
|
|
|
|
|
|
|
s_wcd.windowWidth = rect.right - rect.left;
|
|
|
|
|
s_wcd.windowHeight = rect.bottom - rect.top;
|
|
|
|
|
|
|
|
|
|
s_wcd.hWnd = CreateWindowEx( WS_EX_DLGMODALFRAME, SYSCONSOLE, Title, DEDSTYLE, ( swidth - 600 ) / 2, ( sheight - 450 ) / 2 , rect.right - rect.left + 1, rect.bottom - rect.top + 1, NULL, NULL, base_hInstance, NULL );
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( s_wcd.hWnd == NULL )
|
2007-11-14 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
Msg( "Can't create window '%s'\n", Title );
|
|
|
|
|
return;
|
|
|
|
|
}
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
|
|
|
|
// create fonts
|
|
|
|
|
hDC = GetDC( s_wcd.hWnd );
|
2010-07-24 22:00:00 +02:00
|
|
|
|
nHeight = -MulDiv( fontsize, GetDeviceCaps( hDC, LOGPIXELSY ), 72 );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
s_wcd.hfBufferFont = CreateFont( nHeight, 0, 0, 0, FW_LIGHT, 0, 0, 0, DEFAULT_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, FF_MODERN | FIXED_PITCH, FontName );
|
|
|
|
|
ReleaseDC( s_wcd.hWnd, hDC );
|
|
|
|
|
|
2008-08-04 22:00:00 +02:00
|
|
|
|
if( !Sys.con_readonly )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
// create the input line
|
2010-02-18 22:00:00 +01:00
|
|
|
|
s_wcd.hwndInputLine = CreateWindowEx( WS_EX_CLIENTEDGE, "edit", NULL, WS_CHILD|WS_VISIBLE|WS_BORDER|ES_LEFT|ES_AUTOHSCROLL, 0, 366, 550, 25, s_wcd.hWnd, ( HMENU )INPUT_ID, base_hInstance, NULL );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
s_wcd.hwndButtonSubmit = CreateWindow( "button", NULL, BS_PUSHBUTTON|WS_VISIBLE|WS_CHILD|BS_DEFPUSHBUTTON, 552, 367, 87, 25, s_wcd.hWnd, ( HMENU )SUBMIT_ID, base_hInstance, NULL );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
SendMessage( s_wcd.hwndButtonSubmit, WM_SETTEXT, 0, ( LPARAM ) "submit" );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// create the scrollbuffer
|
2008-08-04 22:00:00 +02:00
|
|
|
|
GetClientRect( s_wcd.hWnd, &rect );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
s_wcd.hwndBuffer = CreateWindowEx( WS_EX_DLGMODALFRAME|WS_EX_CLIENTEDGE, "edit", NULL, CONSTYLE, 0, 0, rect.right - rect.left, min(365, rect.bottom), s_wcd.hWnd, ( HMENU )EDIT_ID, base_hInstance, NULL );
|
|
|
|
|
SendMessage( s_wcd.hwndBuffer, WM_SETFONT, ( WPARAM )s_wcd.hfBufferFont, 0 );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( !Sys.con_readonly )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
s_wcd.SysInputLineWndProc = ( WNDPROC )SetWindowLong( s_wcd.hwndInputLine, GWL_WNDPROC, ( long )Con_InputLineProc );
|
|
|
|
|
SendMessage( s_wcd.hwndInputLine, WM_SETFONT, ( WPARAM )s_wcd.hfBufferFont, 0 );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// show console if needed
|
2007-11-11 22:00:00 +01:00
|
|
|
|
if( Sys.con_showalways )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
|
|
|
|
// make console visible
|
|
|
|
|
ShowWindow( s_wcd.hWnd, SW_SHOWDEFAULT);
|
|
|
|
|
UpdateWindow( s_wcd.hWnd );
|
|
|
|
|
SetForegroundWindow( s_wcd.hWnd );
|
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( Sys.con_readonly ) SetFocus( s_wcd.hWnd );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
else SetFocus( s_wcd.hwndInputLine );
|
|
|
|
|
s_wcd.status = true;
|
|
|
|
|
}
|
|
|
|
|
else s_wcd.status = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
================
|
|
|
|
|
Con_DestroyConsole
|
|
|
|
|
|
|
|
|
|
destroy win32 console
|
|
|
|
|
================
|
|
|
|
|
*/
|
|
|
|
|
void Con_DestroyConsole( void )
|
|
|
|
|
{
|
|
|
|
|
// last text message into console or log
|
2010-07-29 22:00:00 +02:00
|
|
|
|
MsgDev( D_NOTE, "Sys_FreeLibrary: Unloading platform.dll\n" );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2007-12-11 22:00:00 +01:00
|
|
|
|
Sys_CloseLog();
|
2008-08-04 22:00:00 +02:00
|
|
|
|
if( Sys.hooked_out ) return;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( s_wcd.hWnd )
|
2007-11-10 22:00:00 +01:00
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
DeleteObject( s_wcd.hbrEditBackground );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
DeleteObject( s_wcd.hfBufferFont );
|
|
|
|
|
|
|
|
|
|
ShowWindow( s_wcd.hWnd, SW_HIDE );
|
|
|
|
|
DestroyWindow( s_wcd.hWnd );
|
|
|
|
|
s_wcd.hWnd = 0;
|
|
|
|
|
}
|
2008-08-04 22:00:00 +02:00
|
|
|
|
UnregisterClass( SYSCONSOLE, Sys.hInstance );
|
2010-02-18 22:00:00 +01:00
|
|
|
|
|
|
|
|
|
// place it here in case Sys_Crash working properly
|
|
|
|
|
if( Sys.hMutex ) CloseHandle( Sys.hMutex );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
================
|
|
|
|
|
Sys_Input
|
|
|
|
|
|
|
|
|
|
returned input text
|
|
|
|
|
================
|
|
|
|
|
*/
|
|
|
|
|
char *Sys_Input( void )
|
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( s_wcd.consoleText[0] == 0 )
|
|
|
|
|
return NULL;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
2010-02-18 22:00:00 +01:00
|
|
|
|
com_strncpy( s_wcd.returnedText, s_wcd.consoleText, sizeof( s_wcd.returnedText ));
|
2007-11-10 22:00:00 +01:00
|
|
|
|
s_wcd.consoleText[0] = 0;
|
|
|
|
|
|
|
|
|
|
return s_wcd.returnedText;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
================
|
|
|
|
|
Con_SetFocus
|
|
|
|
|
|
|
|
|
|
change focus to console hwnd
|
|
|
|
|
================
|
|
|
|
|
*/
|
|
|
|
|
void Con_RegisterHotkeys( void )
|
|
|
|
|
{
|
2010-02-18 22:00:00 +01:00
|
|
|
|
if( Sys.hooked_out ) return;
|
2007-11-10 22:00:00 +01:00
|
|
|
|
|
|
|
|
|
SetFocus( s_wcd.hWnd );
|
|
|
|
|
|
2007-11-25 22:00:00 +01:00
|
|
|
|
// user can hit escape for quit
|
2009-01-13 22:00:00 +01:00
|
|
|
|
RegisterHotKey( s_wcd.hWnd, QUIT_ON_ESCAPE_ID, 0, VK_ESCAPE );
|
2008-08-04 22:00:00 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
===============================================================================
|
|
|
|
|
|
|
|
|
|
SYSTEM LOG
|
|
|
|
|
|
|
|
|
|
===============================================================================
|
|
|
|
|
*/
|
|
|
|
|
void Sys_InitLog( void )
|
|
|
|
|
{
|
|
|
|
|
const char *mode;
|
|
|
|
|
|
|
|
|
|
if( Sys.app_state == SYS_RESTART )
|
|
|
|
|
mode = "a";
|
|
|
|
|
else mode = "w";
|
|
|
|
|
|
|
|
|
|
// create log if needed
|
|
|
|
|
if( Sys.log_active && !Sys.con_silentmode )
|
|
|
|
|
{
|
|
|
|
|
Sys.logfile = fopen( Sys.log_path, mode );
|
|
|
|
|
if(!Sys.logfile) MsgDev( D_ERROR, "Sys_InitLog: can't create log file %s\n", Sys.log_path );
|
|
|
|
|
|
|
|
|
|
fprintf( Sys.logfile, "=======================================================================\n" );
|
2010-02-10 22:00:00 +01:00
|
|
|
|
fprintf( Sys.logfile, "\t%s started at %s\n", Sys.caption, com_timestamp( TIME_FULL ));
|
2008-08-04 22:00:00 +02:00
|
|
|
|
fprintf( Sys.logfile, "=======================================================================\n");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void Sys_CloseLog( void )
|
|
|
|
|
{
|
|
|
|
|
string event_name;
|
|
|
|
|
|
|
|
|
|
// continue logged
|
|
|
|
|
switch( Sys.app_state )
|
|
|
|
|
{
|
2010-02-10 22:00:00 +01:00
|
|
|
|
case SYS_CRASH: com_strncpy( event_name, "crashed", MAX_STRING ); break;
|
2008-08-04 22:00:00 +02:00
|
|
|
|
case SYS_ABORT: com_strncpy( event_name, "aborted by user", MAX_STRING ); break;
|
|
|
|
|
case SYS_ERROR: com_strncpy( event_name, "stopped with error", MAX_STRING ); break;
|
|
|
|
|
case SYS_RESTART: com_strncpy( event_name, "restarted", MAX_STRING ); break;
|
|
|
|
|
default: com_strncpy( event_name, "stopped", MAX_STRING ); break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( Sys.logfile )
|
|
|
|
|
{
|
|
|
|
|
fprintf( Sys.logfile, "\n");
|
|
|
|
|
fprintf( Sys.logfile, "=======================================================================");
|
|
|
|
|
fprintf( Sys.logfile, "\n\t%s %s at %s\n", Sys.caption, event_name, com_timestamp(TIME_FULL));
|
|
|
|
|
fprintf( Sys.logfile, "=======================================================================\n");
|
|
|
|
|
if( Sys.app_state == SYS_RESTART ) fprintf( Sys.logfile, "\n" ); // just for tabulate
|
|
|
|
|
|
|
|
|
|
fclose( Sys.logfile );
|
|
|
|
|
Sys.logfile = NULL;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void Sys_PrintLog( const char *pMsg )
|
|
|
|
|
{
|
|
|
|
|
if( !Sys.logfile ) return;
|
|
|
|
|
fprintf( Sys.logfile, pMsg );
|
2007-11-10 22:00:00 +01:00
|
|
|
|
}
|