480 lines
17 KiB
C++
480 lines
17 KiB
C++
//========= Copyright Valve Corporation, All rights reserved. ============//
|
|
//
|
|
// VXCONSOLE.H
|
|
//
|
|
// Master Header.
|
|
//=====================================================================================//
|
|
#pragma once
|
|
|
|
#include "tier0/platform.h"
|
|
|
|
#include <winsock2.h>
|
|
#include <windows.h>
|
|
#include <windowsx.h>
|
|
#include <commctrl.h>
|
|
#include <stdio.h>
|
|
#include <stdarg.h>
|
|
#include <io.h>
|
|
#include <fcntl.h>
|
|
#include <string.h>
|
|
#include <share.h>
|
|
#include <richedit.h>
|
|
#include <assert.h>
|
|
#include <xbdm.h>
|
|
#include <time.h>
|
|
#include <sys/stat.h>
|
|
|
|
#include "resource.h"
|
|
#include "assert_resource.h"
|
|
#include "sys_utils.h"
|
|
#include "sys_scriptlib.h"
|
|
#include "bugreporter/bugreporter.h"
|
|
#include "jpeglib/jpeglib.h"
|
|
#include "UtlBuffer.h"
|
|
#include "strtools.h"
|
|
#include "xbox/xbox_vxconsole.h"
|
|
#include "UtlRBTree.h"
|
|
#include "UtlSymbol.h"
|
|
#include "UtlVector.h"
|
|
#include "UtlString.h"
|
|
|
|
#define VXCONSOLE_VERSION "1.2"
|
|
#define VXCONSOLE_CLASSNAME "VXConsole"
|
|
#define VXCONSOLE_TITLE "VXConsole"
|
|
#define VXCONSOLE_FONT "Courier"
|
|
#define VXCONSOLE_FONTSIZE 10
|
|
#define VXCONSOLE_MAGIC "3\\"
|
|
#define VXCONSOLE_REGISTRY "HKEY_CURRENT_USER\\Software\\VXConsole\\" VXCONSOLE_MAGIC
|
|
#ifdef _DEBUG
|
|
#define VXCONSOLE_BUILDTYPE "Debug"
|
|
#else
|
|
#define VXCONSOLE_BUILDTYPE "Release"
|
|
#endif
|
|
|
|
#define VXCONSOLE_WINDOWBYTES ( DLGWINDOWEXTRA + 4 )
|
|
#define VXCONSOLE_CONFIGID ( VXCONSOLE_WINDOWBYTES - 4 )
|
|
|
|
#define MAX_QUEUEDSTRINGS 4096
|
|
#define MAX_QUEUEDSTRINGLEN 512
|
|
#define MAX_RCMDNAMELEN 32
|
|
#define MAX_RCMDS 4096
|
|
#define MAX_TOKENCHARS 256
|
|
#define MAX_XBOXNAMELEN 64
|
|
#define MAX_ARGVELEMS 20
|
|
#define MAX_COMMANDHISTORY 25
|
|
|
|
#define TIMERID_AUTOCONNECT 0x1000
|
|
#define TIMERID_MEMPROFILE 0x1001
|
|
|
|
#define IDC_COMMANDHINT 666
|
|
|
|
#define XBX_CLR_RED ( RGB( 255,0,0 ) )
|
|
#define XBX_CLR_GREEN ( RGB( 0,255,0 ) )
|
|
#define XBX_CLR_WHITE ( RGB( 255,255,255 ) )
|
|
#define XBX_CLR_BLACK ( RGB( 0,0,0 ) )
|
|
#define XBX_CLR_BLUE ( RGB( 0,0,255 ) )
|
|
#define XBX_CLR_YELLOW ( RGB( 255,255,0 ) )
|
|
#define XBX_CLR_LTGREY ( RGB( 180,180,180 ) )
|
|
#define XBX_CLR_DEFAULT XBX_CLR_BLACK
|
|
|
|
// The command prefix that is prepended to all communication between the Xbox
|
|
// app and the debug console app
|
|
#define VXCONSOLE_PRINT_PREFIX "XPRT"
|
|
#define VXCONSOLE_COMMAND_PREFIX "XCMD"
|
|
#define VXCONSOLE_COMMAND_ACK "XACK"
|
|
#define VXCONSOLE_COLOR_PREFIX "XCLR"
|
|
|
|
#define ICON_APPLICATION 0
|
|
#define ICON_DISCONNECTED 1
|
|
#define ICON_CONNECTED_XBOX 2
|
|
#define ICON_CONNECTED_APP0 3
|
|
#define ICON_CONNECTED_APP1 4
|
|
#define MAX_ICONS 5
|
|
|
|
typedef BOOL ( *cmdHandler_t )( int argc, char* argv[] );
|
|
|
|
#define IDM_BINDINGS 50000
|
|
#define IDM_BINDINGS_EDIT ( IDM_BINDINGS+1 )
|
|
#define IDM_BINDINGS_BIND1 ( IDM_BINDINGS+2 )
|
|
#define IDM_BINDINGS_BIND2 ( IDM_BINDINGS+3 )
|
|
#define IDM_BINDINGS_BIND3 ( IDM_BINDINGS+4 )
|
|
#define IDM_BINDINGS_BIND4 ( IDM_BINDINGS+5 )
|
|
#define IDM_BINDINGS_BIND5 ( IDM_BINDINGS+6 )
|
|
#define IDM_BINDINGS_BIND6 ( IDM_BINDINGS+7 )
|
|
#define IDM_BINDINGS_BIND7 ( IDM_BINDINGS+8 )
|
|
#define IDM_BINDINGS_BIND8 ( IDM_BINDINGS+9 )
|
|
#define IDM_BINDINGS_BIND9 ( IDM_BINDINGS+10 )
|
|
#define IDM_BINDINGS_BIND10 ( IDM_BINDINGS+11 )
|
|
#define IDM_BINDINGS_BIND11 ( IDM_BINDINGS+12 )
|
|
#define IDM_BINDINGS_BIND12 ( IDM_BINDINGS+13 )
|
|
#define MAX_BINDINGS ( VK_F12-VK_F1+1 )
|
|
|
|
// file serving
|
|
#define FSERVE_LOCALONLY 0
|
|
#define FSERVE_REMOTEONLY 1
|
|
#define FSERVE_LOCALFIRST 2
|
|
|
|
// file sync
|
|
#define FSYNC_OFF 0x00000000
|
|
#define FSYNC_ALWAYS 0x00000001
|
|
#define FSYNC_IFNEWER 0x00000002
|
|
#define FSYNC_TYPEMASK 0x0000000F
|
|
#define FSYNC_ANDEXISTSONTARGET 0x80000000
|
|
|
|
// track function invocations
|
|
typedef enum
|
|
{
|
|
FL_INVALID,
|
|
FL_STAT,
|
|
FL_FOPEN,
|
|
FL_FSEEK,
|
|
FL_FTELL,
|
|
FL_FREAD,
|
|
FL_FWRITE,
|
|
FL_FCLOSE,
|
|
FL_FEOF,
|
|
FL_FERROR,
|
|
FL_FFLUSH,
|
|
FL_FGETS,
|
|
FL_MAXFUNCTIONCOUNTS,
|
|
} fileLogFunctions_e;
|
|
|
|
typedef enum
|
|
{
|
|
VPROF_OFF = 0,
|
|
VPROF_CPU,
|
|
VPROF_TEXTURE,
|
|
VPROF_TEXTUREFRAME,
|
|
} vprofState_e;
|
|
|
|
// funtion command types
|
|
#define FN_CONSOLE 0x00 // command runs at console
|
|
#define FN_XBOX 0x01 // command requires xbox
|
|
#define FN_APP 0x02 // command requires application
|
|
|
|
// shorthand
|
|
#define FA_NORMAL FILE_ATTRIBUTE_NORMAL
|
|
#define FA_DIRECTORY FILE_ATTRIBUTE_DIRECTORY
|
|
#define FA_READONLY FILE_ATTRIBUTE_READONLY
|
|
|
|
typedef struct
|
|
{
|
|
const CHAR* strCommand;
|
|
int flags;
|
|
cmdHandler_t pfnHandler;
|
|
const CHAR* strHelp;
|
|
} localCommand_t;
|
|
|
|
typedef struct
|
|
{
|
|
char* strCommand;
|
|
char* strHelp;
|
|
} remoteCommand_t;
|
|
|
|
typedef struct
|
|
{
|
|
CRITICAL_SECTION CriticalSection;
|
|
int numMessages;
|
|
bool bInit;
|
|
COLORREF aColors[MAX_QUEUEDSTRINGS];
|
|
CHAR *pMessages[MAX_QUEUEDSTRINGS];
|
|
} printQueue_t;
|
|
|
|
class CProgress
|
|
{
|
|
public:
|
|
CProgress();
|
|
~CProgress();
|
|
void Open( const char* title, bool canCancel, bool bHasMeter );
|
|
void SetStatus( const char *line1, const char *line2, const char *line3 );
|
|
void SetMeter( int currentPos, int range );
|
|
bool IsCancel();
|
|
HWND m_hWnd;
|
|
HWND m_hWndStatus1;
|
|
HWND m_hWndStatus2;
|
|
HWND m_hWndStatus3;
|
|
HWND m_hWndPercent;
|
|
HWND m_hWndMeter;
|
|
HWND m_hWndCancel;
|
|
bool m_bCancelPressed;
|
|
int m_range;
|
|
|
|
private:
|
|
void Update();
|
|
};
|
|
|
|
typedef struct fileNode_s
|
|
{
|
|
char *filename;
|
|
FILETIME creationTime;
|
|
FILETIME changeTime;
|
|
DWORD sizeHigh;
|
|
DWORD sizeLow;
|
|
DWORD attributes;
|
|
int level;
|
|
struct fileNode_s *nextPtr;
|
|
bool needsUpdate;
|
|
}
|
|
fileNode_t;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// FILEIO.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void RemoteToLocalFilename( const char* inFilename, char* outFilename, int outSize );
|
|
extern void RemoteToTargetFilename( const char* inFilename, char* outFilename, int outSize );
|
|
extern void FreeTargetFileList( fileNode_t* pFileList );
|
|
extern bool GetTargetFileList_r( char* targetPath, bool recurse, int attributes, int level, fileNode_t** pFileList );
|
|
extern char *SystemTimeToString( SYSTEMTIME *systemTime, char *buffer, int bufferSize );
|
|
extern bool CreateTargetPath( const char *pTargetFilename );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// BINDINGS.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern bool Bindings_TranslateKey( int vkKeyCode );
|
|
extern bool Bindings_MenuSelection( int wID );
|
|
extern void Bindings_LoadConfig();
|
|
extern void Bindings_SaveConfig();
|
|
extern void Bindings_Open();
|
|
extern bool Bindings_Init();
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// COMMON.CPP
|
|
//-----------------------------------------------------------------------------
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// VXCONSOLE.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void SetConnectionIcon( int icon );
|
|
extern void PrintToQueue( COLORREF color, const CHAR* strFormat, ... );
|
|
extern void ProcessPrintQueue();
|
|
extern void DmAPI_DisplayError( const char* strApiName, HRESULT hr );
|
|
extern int ConsoleWindowPrintf( COLORREF rgb, LPCTSTR lpFmt, ... );
|
|
extern int CmdToArgv( char* str, char* argv[], int maxargs );
|
|
extern char* GetToken( char** tokenStreamPtr );
|
|
extern void DebugCommand( const char* strFormat, ... );
|
|
extern bool ProcessCommand( const char* strCmd );
|
|
extern HRESULT DmAPI_SendCommand( const char* strCommand, bool wait );
|
|
extern void NotImplementedYet();
|
|
extern void SetMainWindowTitle();
|
|
extern HWND g_hDlgMain;
|
|
extern HWND g_hwndOutputWindow;
|
|
extern UINT_PTR g_autoConnectTimer;
|
|
extern BOOL g_autoConnect;
|
|
extern CHAR g_xboxName[];
|
|
extern DWORD g_xboxAddress;
|
|
extern CHAR g_remotePath[];
|
|
extern CHAR g_localPath[];
|
|
extern CHAR g_targetPath[];
|
|
extern CHAR g_installPath[];
|
|
extern CHAR g_xboxTargetName[];
|
|
extern BOOL g_connectedToApp;
|
|
extern BOOL g_connectedToXBox;
|
|
extern PDMN_SESSION g_pdmnSession;
|
|
extern PDM_CONNECTION g_pdmConnection;
|
|
extern BOOL g_debugCommands;
|
|
extern BOOL g_captureDebugSpew;
|
|
extern HINSTANCE g_hInstance;
|
|
extern HICON g_hIcons[];
|
|
extern BOOL g_reboot;
|
|
extern int g_rebootArgc;
|
|
extern char* g_rebootArgv[];
|
|
extern int g_connectCount;
|
|
extern int g_currentIcon;
|
|
extern BOOL g_clsOnConnect;
|
|
extern DWORD g_connectedTime;
|
|
extern HBRUSH g_hBackgroundBrush;
|
|
extern COLORREF g_backgroundColor;
|
|
extern HFONT g_hFixedFont;
|
|
extern HFONT g_hProportionalFont;
|
|
extern HANDLE g_hCommandReadyEvent;
|
|
extern BOOL g_loadSymbolsOnConnect;
|
|
extern HACCEL g_hAccel;
|
|
extern BOOL g_alwaysAutoConnect;
|
|
extern BOOL g_startMinimized;
|
|
extern int g_connectFailure;
|
|
extern BOOL g_captureDebugSpew_StartupState;
|
|
extern bool g_bSuppressBlink;
|
|
extern BOOL g_bPlayTestMode;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// LOCAL_CMDS.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern BOOL lc_bug( int argc, char* argv[] );
|
|
extern BOOL lc_dir( int argc, char* argv[] );
|
|
extern BOOL lc_del( int argc, char* argv[] );
|
|
extern BOOL lc_memory( int argc, char* argv[] );
|
|
extern BOOL lc_screenshot( int argc, char* argv[] );
|
|
extern BOOL lc_help( int argc, char* argv[] );
|
|
extern BOOL lc_cls( int argc, char* argv[] );
|
|
extern BOOL lc_connect( int argc, char* argv[] );
|
|
extern BOOL lc_autoConnect( int argc, char* argv[] );
|
|
extern BOOL lc_disconnect( int argc, char* argv[] );
|
|
extern BOOL lc_quit( int argc, char* argv[] );
|
|
extern BOOL lc_crashdump( int argc, char* argv[] );
|
|
extern BOOL lc_listen( int argc, char* argv[] );
|
|
extern BOOL lc_run( int argc, char* argv[] );
|
|
extern BOOL lc_reset( int argc, char* argv[] );
|
|
extern BOOL lc_modules( int argc, char* argv[] );
|
|
extern BOOL lc_sections( int argc, char* argv[] );
|
|
extern BOOL lc_threads( int argc, char* argv[] );
|
|
extern BOOL lc_ClearConfigs( int argc, char* argv[] );
|
|
extern void AutoConnectTimerProc( HWND hwnd, UINT_PTR idEvent );
|
|
extern int MatchLocalCommands( char* cmdStr, const char* cmdList[], int maxCmds );
|
|
extern void DoDisconnect( BOOL bKeepConnection, int waitTime = 15 );
|
|
extern localCommand_t g_localCommands[];
|
|
extern const int g_numLocalCommands;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// REMOTE_CMDS.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern int rc_AddCommands( char* commandPtr );
|
|
extern void Remote_DeleteCommands();
|
|
extern DWORD __stdcall Remote_NotifyDebugString( ULONG dwNotification, DWORD dwParam );
|
|
extern DWORD __stdcall Remote_NotifyPrintFunc( const CHAR* strNotification );
|
|
extern DWORD __stdcall Remote_NotifyCommandFunc( const CHAR* strNotification );
|
|
extern int MatchRemoteCommands( char* cmdStr, const char* cmdList[], int maxCmds );
|
|
extern remoteCommand_t* g_remoteCommands[];
|
|
extern int g_numRemoteCommands;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// BUG.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern bool BugDlg_Init( void );
|
|
extern void BugDlg_Open( void );
|
|
extern void BugReporter_FreeInterfaces();
|
|
extern int rc_MapInfo( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// CONFIG.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void ConfigDlg_Open( void );
|
|
extern void ConfigDlg_LoadConfig();
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// FILELOG.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void FileLog_Open();
|
|
extern bool FileLog_Init();
|
|
extern void FileLog_Clear();
|
|
extern unsigned int FileLog_AddItem( const char* filename, unsigned int fp );
|
|
extern void FileLog_UpdateItem( unsigned int log, unsigned int fp, fileLogFunctions_e functionId, int value );
|
|
extern void FileLog_SaveConfig();
|
|
extern void FileLog_LoadConfig();
|
|
extern bool g_fileLogEnable;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// CPU_PROFILE.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void CpuProfileSamples_Open();
|
|
extern void CpuProfileHistory_Open();
|
|
extern void CpuProfile_SetTitle();
|
|
extern bool CpuProfile_Init();
|
|
extern void CpuProfile_Clear();
|
|
extern int rc_SetCpuProfile( char* commandPtr );
|
|
extern int rc_SetCpuProfileData( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// TEX_PROFILE.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void TexProfile_SetTitle();
|
|
extern void TexProfileSamples_Open();
|
|
extern void TexProfileHistory_Open();
|
|
extern bool TexProfile_Init();
|
|
extern int rc_SetTexProfile( char* commandPtr );
|
|
extern int rc_SetTexProfileData( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// MEM_PROFILE.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void MemProfile_Open();
|
|
extern void MemProfile_SetTitle();
|
|
extern bool MemProfile_Init();
|
|
extern void MemProfile_Clear();
|
|
extern int rc_FreeMemory( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// MEMLOG.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void MemoryLog_Open();
|
|
extern bool MemoryLog_Init();
|
|
extern void MemoryLog_Clear();
|
|
extern void MemoryLog_SaveConfig();
|
|
extern void MemoryLog_LoadConfig();
|
|
extern void MemoryLog_TreeView( bool enable );
|
|
extern void MemoryLog_RefreshItems();
|
|
extern int rc_MemoryLog( char* commandPtr );
|
|
extern bool g_memoryLog_enable;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// SYNC_FILES.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern int FileSyncEx( const char* localFilename, const char* remoteFilename, int fileSyncMode, bool bVerbose, bool bNoWrite );
|
|
extern bool SyncFilesDlg_Init( void );
|
|
extern void SyncFilesDlg_Open( void );
|
|
extern void InstallDlg_Open( void );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// FILEIO.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern int CompareFileTimes_NTFStoFATX( FILETIME* ntfsFileTime, char *ntfsTimeString, int ntfsStringSize, FILETIME* fatxFileTime, char *fatxTimeString, int fatxStringSize );
|
|
extern bool LoadTargetFile( const char *pTargetPath, int *pFileSize, void **pData );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// PROGRESS.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern bool Progress_Init();
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// SHOW_TEXTURES.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void ShowTextures_Open();
|
|
extern bool ShowTextures_Init();
|
|
extern int rc_TextureList( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// TIMESTAMP_LOG.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void TimeStampLog_Open();
|
|
extern bool TimeStampLog_Init();
|
|
extern void TimeStampLog_Clear();
|
|
extern int rc_TimeStampLog( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// COMMON.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern vprofState_e VProf_GetState();
|
|
extern void VProf_Enable( vprofState_e state );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// SHOW_MATERIALS.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void ShowMaterials_Open();
|
|
extern bool ShowMaterials_Init();
|
|
extern int rc_MaterialList( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// SHOW_SOUNDS.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void ShowSounds_Open();
|
|
extern bool ShowSounds_Init();
|
|
extern int rc_SoundList( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// SHOW_MEMDUMP.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern void ShowMemDump_Open();
|
|
extern bool ShowMemDump_Init();
|
|
extern int rc_MemDump( char* commandPtr );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// EXCLUDE_PATHS.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern bool ExcludePathsDlg_Init( void );
|
|
extern void ExcludePathsDlg_Open( void );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// ASSERT_DIALOG.CPP
|
|
//-----------------------------------------------------------------------------
|
|
extern bool g_AssertDialogActive;
|
|
int rc_Assert( char *commandPtr );
|