2010-05-22 04:47:15 +00:00
|
|
|
#include "stdafx.h"
|
2012-12-29 10:50:45 +00:00
|
|
|
#include <Tlhelp32.h>
|
2008-09-18 03:15:49 +00:00
|
|
|
|
2010-06-04 06:25:07 +00:00
|
|
|
CTraceFileLog * LogFile = NULL;
|
|
|
|
|
2008-09-18 03:15:49 +00:00
|
|
|
void LogLevelChanged (CTraceFileLog * LogFile)
|
|
|
|
{
|
2012-11-17 01:02:04 +00:00
|
|
|
LogFile->SetTraceLevel((TraceLevel)g_Settings->LoadDword(Debugger_AppLogLevel));
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void LogFlushChanged (CTraceFileLog * LogFile)
|
|
|
|
{
|
2012-11-17 01:02:04 +00:00
|
|
|
LogFile->SetFlushFile(g_Settings->LoadDword(Debugger_AppLogFlush) != 0);
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void InitializeLog ( void)
|
|
|
|
{
|
2010-05-14 23:28:15 +00:00
|
|
|
CPath LogFilePath(CPath::MODULE_DIRECTORY);
|
|
|
|
LogFilePath.AppendDirectory("Logs");
|
|
|
|
if (!LogFilePath.DirectoryExists())
|
|
|
|
{
|
|
|
|
LogFilePath.CreateDirectory();
|
|
|
|
}
|
2015-08-20 03:00:41 +00:00
|
|
|
LogFilePath.SetNameExtension("Project64.log");
|
2008-09-18 03:15:49 +00:00
|
|
|
|
2012-11-17 01:02:04 +00:00
|
|
|
LogFile = new CTraceFileLog(LogFilePath, g_Settings->LoadDword(Debugger_AppLogFlush) != 0, Log_New,500);
|
2008-11-17 10:02:22 +00:00
|
|
|
#ifdef VALIDATE_DEBUG
|
2012-11-17 01:02:04 +00:00
|
|
|
LogFile->SetTraceLevel((TraceLevel)(g_Settings->LoadDword(Debugger_AppLogLevel) | TraceValidate));
|
2008-11-17 10:02:22 +00:00
|
|
|
#else
|
2012-11-17 01:02:04 +00:00
|
|
|
LogFile->SetTraceLevel((TraceLevel)g_Settings->LoadDword(Debugger_AppLogLevel));
|
2008-11-17 10:02:22 +00:00
|
|
|
#endif
|
2008-09-18 03:15:49 +00:00
|
|
|
AddTraceModule(LogFile);
|
|
|
|
|
2012-11-17 01:02:04 +00:00
|
|
|
g_Settings->RegisterChangeCB(Debugger_AppLogLevel,LogFile,(CSettings::SettingChangedFunc)LogLevelChanged);
|
|
|
|
g_Settings->RegisterChangeCB(Debugger_AppLogFlush,LogFile,(CSettings::SettingChangedFunc)LogFlushChanged);
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
2010-06-04 06:25:07 +00:00
|
|
|
|
2010-05-14 23:28:15 +00:00
|
|
|
/*bool ChangeDirPermission ( const CPath & Dir)
|
|
|
|
{
|
|
|
|
if (Dir.DirectoryExists())
|
|
|
|
{
|
|
|
|
HANDLE hDir = CreateFile(Dir,READ_CONTROL|WRITE_DAC,0,NULL,OPEN_EXISTING,FILE_FLAG_BACKUP_SEMANTICS,NULL);
|
|
|
|
if (hDir != INVALID_HANDLE_VALUE)
|
|
|
|
{
|
|
|
|
ACL * pOldDACL = NULL;
|
|
|
|
PSECURITY_DESCRIPTOR pSD = NULL;
|
|
|
|
|
|
|
|
if (GetSecurityInfo(hDir,SE_FILE_OBJECT,DACL_SECURITY_INFORMATION,NULL,NULL,&pOldDACL,NULL,&pSD) == ERROR_SUCCESS)
|
|
|
|
{
|
|
|
|
bool bAdd = true;
|
|
|
|
|
|
|
|
PEXPLICIT_ACCESS_W pListOfExplictEntries;
|
|
|
|
ULONG cCountOfExplicitEntries;
|
|
|
|
if (GetExplicitEntriesFromAclW(pOldDACL,&cCountOfExplicitEntries,&pListOfExplictEntries) == ERROR_SUCCESS)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < cCountOfExplicitEntries; i ++)
|
|
|
|
{
|
|
|
|
EXPLICIT_ACCESS_W &ea = pListOfExplictEntries[i];
|
|
|
|
if (ea.grfAccessMode != GRANT_ACCESS) { continue; }
|
|
|
|
if (ea.grfAccessPermissions != GENERIC_ALL) { continue; }
|
|
|
|
if ((ea.grfInheritance & (CONTAINER_INHERIT_ACE|OBJECT_INHERIT_ACE)) != (CONTAINER_INHERIT_ACE|OBJECT_INHERIT_ACE)) { continue; }
|
|
|
|
|
|
|
|
if (ea.Trustee.TrusteeType == TRUSTEE_IS_SID)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
bAdd = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bAdd)
|
|
|
|
{
|
|
|
|
EXPLICIT_ACCESS ea = {0};
|
|
|
|
ea.grfAccessMode = GRANT_ACCESS;
|
|
|
|
ea.grfAccessPermissions = GENERIC_ALL;
|
|
|
|
ea.grfInheritance = CONTAINER_INHERIT_ACE|OBJECT_INHERIT_ACE;
|
|
|
|
ea.Trustee.TrusteeType = TRUSTEE_IS_GROUP;
|
|
|
|
ea.Trustee.TrusteeForm = TRUSTEE_IS_NAME;
|
|
|
|
ea.Trustee.ptstrName = TEXT("Users");
|
|
|
|
|
|
|
|
ACL * pNewDACL = NULL;
|
|
|
|
SetEntriesInAcl(1,&ea,pOldDACL,&pNewDACL);
|
|
|
|
|
|
|
|
SetSecurityInfo(hDir,SE_FILE_OBJECT,DACL_SECURITY_INFORMATION,NULL,NULL,pNewDACL,NULL);
|
|
|
|
LocalFree(pNewDACL);
|
|
|
|
}
|
|
|
|
LocalFree(pSD);
|
|
|
|
}
|
|
|
|
CloseHandle(hDir);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}*/
|
|
|
|
|
|
|
|
void FixDirectories ( void )
|
|
|
|
{
|
2010-05-16 06:27:33 +00:00
|
|
|
CPath Directory(CPath::MODULE_DIRECTORY);
|
2015-08-20 03:00:41 +00:00
|
|
|
Directory.AppendDirectory("Config");
|
2013-04-15 03:52:34 +00:00
|
|
|
if (!Directory.DirectoryExists()) Directory.CreateDirectory();
|
2010-05-16 06:27:33 +00:00
|
|
|
|
|
|
|
Directory.UpDirectory();
|
|
|
|
Directory.AppendDirectory("Logs");
|
2013-04-15 03:52:34 +00:00
|
|
|
if (!Directory.DirectoryExists()) Directory.CreateDirectory();
|
2010-05-16 06:27:33 +00:00
|
|
|
|
|
|
|
Directory.UpDirectory();
|
|
|
|
Directory.AppendDirectory("Save");
|
2013-04-15 03:52:34 +00:00
|
|
|
if (!Directory.DirectoryExists()) Directory.CreateDirectory();
|
2010-05-16 06:27:33 +00:00
|
|
|
|
|
|
|
Directory.UpDirectory();
|
|
|
|
Directory.AppendDirectory("Screenshots");
|
2013-04-15 03:52:34 +00:00
|
|
|
if (!Directory.DirectoryExists()) Directory.CreateDirectory();
|
2013-04-28 05:49:14 +00:00
|
|
|
|
|
|
|
Directory.UpDirectory();
|
|
|
|
Directory.AppendDirectory("textures");
|
|
|
|
if (!Directory.DirectoryExists()) Directory.CreateDirectory();
|
2010-05-14 23:28:15 +00:00
|
|
|
}
|
|
|
|
|
2012-12-29 10:50:45 +00:00
|
|
|
bool TerminatedExistingEmu()
|
|
|
|
{
|
|
|
|
bool bTerminated = false;
|
|
|
|
bool AskedUser = false;
|
|
|
|
DWORD pid = GetCurrentProcessId();
|
|
|
|
|
|
|
|
HANDLE nSearch = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
|
|
|
|
if(nSearch != INVALID_HANDLE_VALUE)
|
|
|
|
{
|
|
|
|
PROCESSENTRY32 lppe;
|
|
|
|
|
|
|
|
memset(&lppe, 0, sizeof(PROCESSENTRY32));
|
|
|
|
lppe.dwSize = sizeof(PROCESSENTRY32);
|
|
|
|
stdstr ModuleName = CPath(CPath::MODULE_FILE).GetNameExtension();
|
|
|
|
|
|
|
|
if (Process32First(nSearch, &lppe))
|
|
|
|
{
|
|
|
|
do
|
|
|
|
{
|
|
|
|
if(_stricmp(lppe.szExeFile, ModuleName.c_str()) != 0 ||
|
|
|
|
lppe.th32ProcessID == pid)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (!AskedUser)
|
|
|
|
{
|
|
|
|
AskedUser = true;
|
|
|
|
int res = MessageBox(NULL,stdstr_f("Project64.exe currently running\n\nTerminate pid %d now?",lppe.th32ProcessID).c_str(),"Terminate project64",MB_YESNO|MB_ICONEXCLAMATION);
|
|
|
|
if (res != IDYES)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
HANDLE hHandle = OpenProcess(PROCESS_ALL_ACCESS, FALSE, lppe.th32ProcessID);
|
|
|
|
if(hHandle != NULL)
|
|
|
|
{
|
|
|
|
if (TerminateProcess(hHandle, 0))
|
|
|
|
{
|
|
|
|
bTerminated = true;
|
|
|
|
} else {
|
|
|
|
MessageBox(NULL,stdstr_f("Failed to terminate pid %d",lppe.th32ProcessID).c_str(),"Terminate project64 failed!",MB_YESNO|MB_ICONEXCLAMATION);
|
|
|
|
}
|
|
|
|
CloseHandle(hHandle);
|
|
|
|
}
|
|
|
|
} while (Process32Next(nSearch, &lppe));
|
|
|
|
}
|
|
|
|
CloseHandle(nSearch);
|
|
|
|
}
|
|
|
|
return bTerminated;
|
|
|
|
}
|
|
|
|
|
2015-02-02 19:25:10 +00:00
|
|
|
const char * AppName ( void )
|
|
|
|
{
|
|
|
|
static stdstr Name;
|
|
|
|
if (Name.empty())
|
|
|
|
{
|
2015-02-17 08:28:30 +00:00
|
|
|
Name = stdstr_f("Project64 %s", VER_FILE_VERSION_STR);
|
2015-02-02 19:25:10 +00:00
|
|
|
}
|
|
|
|
return Name.c_str();
|
|
|
|
}
|
|
|
|
|
2015-09-07 19:47:58 +00:00
|
|
|
#ifndef WINDOWS_UI
|
|
|
|
int main(int argc, char* argv[])
|
|
|
|
{
|
2015-09-14 20:04:25 +00:00
|
|
|
while (argc > 0)
|
2015-09-07 19:47:58 +00:00
|
|
|
{
|
|
|
|
puts(argv[--argc]);
|
|
|
|
}
|
2015-09-14 20:03:23 +00:00
|
|
|
putchar('\n');
|
|
|
|
|
|
|
|
fprintf(
|
|
|
|
stderr,
|
|
|
|
"Cross-platform (graphical/terminal?) UI not yet implemented.\n"
|
|
|
|
);
|
2015-09-07 19:47:58 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
int WINAPI WinMain(HINSTANCE /*hInstance*/, HINSTANCE /*hPrevInstance*/, LPSTR /*lpszArgs*/, int /*nWinMode*/)
|
2010-05-14 23:28:15 +00:00
|
|
|
{
|
|
|
|
FixDirectories();
|
|
|
|
|
2008-09-18 03:15:49 +00:00
|
|
|
CoInitialize(NULL);
|
|
|
|
try
|
|
|
|
{
|
2012-09-22 05:53:39 +00:00
|
|
|
SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_ABOVE_NORMAL );
|
2015-03-04 09:36:08 +00:00
|
|
|
g_Lang = new CLanguage();
|
2008-09-18 03:15:49 +00:00
|
|
|
|
2012-11-17 01:02:04 +00:00
|
|
|
g_Settings = new CSettings;
|
2015-04-20 20:01:18 +00:00
|
|
|
g_Settings->Initialize(AppName());
|
2008-09-18 03:15:49 +00:00
|
|
|
|
2012-12-29 10:50:45 +00:00
|
|
|
if (g_Settings->LoadBool(Setting_CheckEmuRunning) &&
|
|
|
|
TerminatedExistingEmu())
|
|
|
|
{
|
|
|
|
delete g_Settings;
|
|
|
|
g_Settings = new CSettings;
|
2015-04-20 20:01:18 +00:00
|
|
|
g_Settings->Initialize(AppName());
|
2012-12-29 10:50:45 +00:00
|
|
|
}
|
|
|
|
|
2008-09-18 03:15:49 +00:00
|
|
|
InitializeLog();
|
|
|
|
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": Application Starting");
|
2012-12-18 10:43:29 +00:00
|
|
|
CMipsMemoryVM::ReserveMemory();
|
|
|
|
|
2012-11-17 00:58:31 +00:00
|
|
|
g_Notify = &Notify();
|
2010-05-22 04:47:15 +00:00
|
|
|
|
2008-09-18 03:15:49 +00:00
|
|
|
//Create the plugin container
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": Create Plugins");
|
2012-11-17 02:20:21 +00:00
|
|
|
g_Plugins = new CPlugins(g_Settings->LoadString(Directory_Plugin));
|
2008-09-18 03:15:49 +00:00
|
|
|
|
|
|
|
//Select the language
|
2015-03-04 09:36:08 +00:00
|
|
|
g_Lang->LoadCurrentStrings(true);
|
2008-09-18 03:15:49 +00:00
|
|
|
|
|
|
|
//Create the main window with Menu
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": Create Main Window");
|
2015-02-02 19:25:10 +00:00
|
|
|
stdstr WinTitle(AppName());
|
2015-02-14 11:17:45 +00:00
|
|
|
|
2015-02-17 08:28:30 +00:00
|
|
|
WinTitle.Format("Project64 %s", VER_FILE_VERSION_STR);
|
2015-02-14 11:17:45 +00:00
|
|
|
|
2010-05-22 04:47:15 +00:00
|
|
|
CMainGui MainWindow(true,WinTitle.c_str()), HiddenWindow(false);
|
|
|
|
CMainMenu MainMenu(&MainWindow);
|
2012-11-17 02:20:21 +00:00
|
|
|
g_Plugins->SetRenderWindows(&MainWindow,&HiddenWindow);
|
2012-11-17 00:58:31 +00:00
|
|
|
g_Notify->SetMainWindow(&MainWindow);
|
2008-09-18 03:15:49 +00:00
|
|
|
|
2015-03-04 09:36:08 +00:00
|
|
|
if (__argc > 1)
|
|
|
|
{
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTraceF(TraceDebug,__FUNCTION__ ": Cmd line found \"%s\"",__argv[1]);
|
2008-09-18 03:15:49 +00:00
|
|
|
MainWindow.Show(true); //Show the main window
|
2010-05-22 04:47:15 +00:00
|
|
|
CN64System::RunFileImage(__argv[1]);
|
2015-03-04 09:36:08 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2012-11-17 01:02:04 +00:00
|
|
|
if (g_Settings->LoadDword(RomBrowser_Enabled))
|
2008-11-14 20:51:06 +00:00
|
|
|
{
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": Show Rom Browser");
|
2008-09-18 03:15:49 +00:00
|
|
|
//Display the rom browser
|
|
|
|
MainWindow.ShowRomList();
|
|
|
|
MainWindow.Show(true); //Show the main window
|
|
|
|
MainWindow.HighLightLastRom();
|
|
|
|
} else {
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": Show Main Window");
|
2008-09-18 03:15:49 +00:00
|
|
|
MainWindow.Show(true); //Show the main window
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//Process Messages till program is closed
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": Entering Message Loop");
|
2008-09-18 03:15:49 +00:00
|
|
|
MainWindow.ProcessAllMessages();
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": Message Loop Finished");
|
2008-09-18 03:15:49 +00:00
|
|
|
|
2012-11-17 01:09:19 +00:00
|
|
|
if (g_BaseSystem)
|
2010-05-22 04:47:15 +00:00
|
|
|
{
|
2012-11-17 01:09:19 +00:00
|
|
|
g_BaseSystem->CloseCpu();
|
|
|
|
delete g_BaseSystem;
|
|
|
|
g_BaseSystem = NULL;
|
2010-05-22 04:47:15 +00:00
|
|
|
}
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": System Closed");
|
2010-06-04 06:25:07 +00:00
|
|
|
|
2012-11-17 01:02:04 +00:00
|
|
|
g_Settings->UnregisterChangeCB(Debugger_AppLogLevel,LogFile,(CSettings::SettingChangedFunc)LogLevelChanged);
|
|
|
|
g_Settings->UnregisterChangeCB(Debugger_AppLogFlush,LogFile,(CSettings::SettingChangedFunc)LogFlushChanged);
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
catch(...)
|
|
|
|
{
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTraceF(TraceError,__FUNCTION__ ": Exception caught (File: \"%s\" Line: %d)",__FILE__,__LINE__);
|
2008-09-18 03:15:49 +00:00
|
|
|
MessageBox(NULL,stdstr_f("Exception caught\nFile: %s\nLine: %d",__FILE__,__LINE__).c_str(),"Exception",MB_OK);
|
|
|
|
}
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": cleaning up global objects");
|
2010-05-22 04:47:15 +00:00
|
|
|
|
2012-11-17 02:24:42 +00:00
|
|
|
if (g_Rom) { delete g_Rom; g_Rom = NULL; }
|
2012-11-17 02:20:21 +00:00
|
|
|
if (g_Plugins) { delete g_Plugins; g_Plugins = NULL; }
|
2012-11-17 01:02:04 +00:00
|
|
|
if (g_Settings) { delete g_Settings; g_Settings = NULL; }
|
2015-03-04 09:36:08 +00:00
|
|
|
if (g_Lang) { delete g_Lang; g_Lang = NULL; }
|
2010-05-22 04:47:15 +00:00
|
|
|
|
2012-12-18 23:55:05 +00:00
|
|
|
CMipsMemoryVM::FreeReservedMemory();
|
|
|
|
|
2008-09-18 03:15:49 +00:00
|
|
|
CoUninitialize();
|
2012-12-17 00:21:29 +00:00
|
|
|
WriteTrace(TraceDebug,__FUNCTION__ ": Done");
|
2008-09-18 03:15:49 +00:00
|
|
|
CloseTrace();
|
|
|
|
return true;
|
|
|
|
}
|
2015-09-07 19:47:58 +00:00
|
|
|
#endif
|