source-engine/utils/tfstats/ui/ui.cpp

269 lines
6.1 KiB
C++
Raw Normal View History

2020-04-22 16:56:21 +00:00
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $NoKeywords: $
//
//=============================================================================//
// UI.cpp : Defines the class behaviors for the application.
//
#include "stdafx.h"
#include "propsht.h"
#include "UI.h"
#include "UIDlg.h"
#include "PersistentString.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CUIApp
BEGIN_MESSAGE_MAP(CUIApp, CWinApp)
//{{AFX_MSG_MAP(CUIApp)
// NOTE - the ClassWizard will add and remove mapping macros here.
// DO NOT EDIT what you see in these blocks of generated code!
//}}AFX_MSG
ON_COMMAND(ID_HELP, CWinApp::OnHelp)
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CUIApp construction
CUIApp::CUIApp()
{
// Place all significant initialization in InitInstance
pause=false;
pauseSecs=0;
CPersistentString cps("RunBefore");
FirstEverTimeRun=!cps.toBool();
cps=true;
}
/////////////////////////////////////////////////////////////////////////////
// The one and only CUIApp object
CUIApp theApp;
/////////////////////////////////////////////////////////////////////////////
// CUIApp initialization
BOOL CUIApp::InitInstance()
{
// Standard initialization
// If you are not using these features and wish to reduce the size
// of your final executable, you should remove from the following
// the specific initialization routines you do not need.
#ifdef _AFXDLL
Enable3dControls(); // Call this when using MFC in a shared DLL
#else
Enable3dControlsStatic(); // Call this when linking to MFC statically
#endif
persistPlayerStats=false;
useSupportDir=true;
displayMM2=false;
CAllControlsSheet dlg("TFStats");
m_pMainWnd = &dlg;
int nResponse = dlg.DoModal();
if (nResponse == IDOK)
{
// TODO: Place code here to handle when the dialog is
// dismissed with OK
execTFStats();
}
else if (nResponse == IDCANCEL)
{
// TODO: Place code here to handle when the dialog is
// dismissed with Cancel
}
// Since the dialog has been closed, return FALSE so that we exit the
// application, rather than start the application's message pump.
return FALSE;
}
void reporterror31337(LONG i)
{
LPVOID lpMsgBuf;
FormatMessage(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
i,
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
(LPTSTR) &lpMsgBuf,
0,
NULL
);
// Process any inserts in lpMsgBuf.
// ...
// Display the string.
MessageBox( NULL, (LPCTSTR)lpMsgBuf, "Error", MB_OK | MB_ICONINFORMATION );
// Free the buffer.
LocalFree( lpMsgBuf );
}
string& addSlash(string& tempbuf)
{
if (tempbuf!="")
{
int buflen=tempbuf.length();
if (tempbuf.at(buflen-1) != '\\')
tempbuf+= '\\';
}
return tempbuf;
}
string& removeSlash(string& tempbuf)
{
int buflen=tempbuf.length();
if (buflen > 0 && tempbuf.at(buflen-1) == '\\')
tempbuf.erase(tempbuf.length()-1,1);
return tempbuf;
}
string CUIApp::CTFStatsExec::getExecString()
{
string retval("\"");
retval+=addSlash(TFStatsdirectory);
retval+="TFStatsRT.exe\" \"" ;
retval+=fullpath;
retval+="\" outputDir=\"";
retval+=addSlash(outputdirectory);
retval+=removeSlash(outputsubdir);
retval+="\" ";
retval+="ruleDir=\"";
retval+=removeSlash(ruledirectory);
retval+="\" ";
retval+=" useSupportDir=";
retval+=useSupportDir?"yes":"no";
if (useSupportDir)
{
retval+=" supportDir=\"";
retval+=removeSlash(supportdirectory);
retval+="\" supportHTTPPath=\"";
retval+=removeSlash(supporthttp);
retval+="\"";
}
retval+=" persistPlayerStats=";
retval+=persistPlayerStats?"yes":"no";
if (persistPlayerStats)
{
retval+=" playerDir=\"";
retval+=removeSlash(playerdirectory);
retval+="\" ";
retval+=" playerHTTPPath=\"";
retval+=removeSlash(playerhttp);
retval+="\"";
}
retval+=" eliminateOldPlayers=";
retval+=elimOldPlayers?"yes":"no";
if (elimOldPlayers)
{
retval+=" oldPlayerCutoff=";
char buf[100];
itoa(elimDays,buf,10);
retval+=buf;
retval+=" ";
}
retval+=" displayMM2=";
retval+=displayMM2?"yes":"no";
retval+=" displayStartUpInfo=";
retval+=displayStartupInfo?"yes":"no";
return retval;
}
#include <list>
void CUIApp::execTFStats()
{
std::list<CUIApp::CTFStatsExec>::iterator it;
AllocConsole();
for (it=m_pLogs->begin();it!=m_pLogs->end();++it)
{
CUIApp::CTFStatsExec& c=*it;
it->TFStatsdirectory=m_TFStatsDir;
it->outputdirectory=m_OutDir;
it->ruledirectory=m_RuleDir;
it->supportdirectory=m_SupportDir;
it->playerdirectory=m_PlayerDir;
it->displayMM2=displayMM2;
it->persistPlayerStats=persistPlayerStats;
it->useSupportDir=useSupportDir;
it->supporthttp=m_SupportHTTPPath;
it->playerhttp=m_PlayerHTTPPath;
it->displayStartupInfo=displayStartupInfo;
it->elimOldPlayers=elimOldPlayers;
it->elimDays=elimDays;
string exec=it->getExecString();
//create process takes a non-const char buffer?
char createProcBuf[4000];
memset(createProcBuf,0,4000);
exec.copy(createProcBuf,4000);
PROCESS_INFORMATION pi;
STARTUPINFO si;
memset(&si,0,sizeof(si));
si.cb=sizeof(si);
char buffer[500];
sprintf(buffer,"TFStats is creating a Match report for %s",it->inputfile.c_str());
si.lpTitle=buffer;
SetConsoleTitle(buffer);
BOOL result=CreateProcess(NULL,createProcBuf,NULL,NULL,FALSE,0,NULL,NULL,&si,&pi);
if (pi.hProcess && result)
{
//wait for this one to finish before running next one!
DWORD exitCode=STILL_ACTIVE;
do
{
GetExitCodeProcess(pi.hProcess,&exitCode);
//check every 10th of a second
if (exitCode==STILL_ACTIVE)
Sleep(100);
if (pause)
Sleep(pauseSecs*1000);
} while (exitCode==STILL_ACTIVE);
}
else
{
string badmojo("***ERROR: Could not run \"");
badmojo+=addSlash(it->TFStatsdirectory);
badmojo+="TFStatsRT.exe\"\n\n";
HANDLE hConsOutput=GetStdHandle(STD_OUTPUT_HANDLE);
WriteConsole(hConsOutput,badmojo.c_str(),badmojo.length(),NULL,0);
Sleep(4000);
}
}
FreeConsole();
}