mirror of https://github.com/snes9xgit/snes9x.git
win32: Ask about registry keys on first start. Also...
add a command-line option to remove these keys.
This commit is contained in:
parent
879134ca5a
commit
036fa5a951
|
@ -40,7 +40,11 @@ extern TCHAR multiRomB[MAX_PATH];
|
||||||
|
|
||||||
void S9xParseArg (char **argv, int &i, int argc)
|
void S9xParseArg (char **argv, int &i, int argc)
|
||||||
{
|
{
|
||||||
if (strcasecmp (argv [i], "-restore") == 0)
|
if (strcasecmp (argv [i], "-removeregistrykeys"))
|
||||||
|
{
|
||||||
|
S9xWinRemoveRegistryKeys();
|
||||||
|
}
|
||||||
|
else if (strcasecmp (argv [i], "-restore") == 0)
|
||||||
{
|
{
|
||||||
WinDeleteRegistryEntries ();
|
WinDeleteRegistryEntries ();
|
||||||
WinSetDefaultValues ();
|
WinSetDefaultValues ();
|
||||||
|
@ -814,7 +818,7 @@ void WinRegisterConfigItems()
|
||||||
AddUIntC("RewindGranularity", GUI.rewindGranularity, 1, "rewind granularity - rewind takes a snapshot each x frames");
|
AddUIntC("RewindGranularity", GUI.rewindGranularity, 1, "rewind granularity - rewind takes a snapshot each x frames");
|
||||||
AddBoolC("PauseWhenInactive", GUI.InactivePause, TRUE, "true to pause Snes9x when it is not the active window");
|
AddBoolC("PauseWhenInactive", GUI.InactivePause, TRUE, "true to pause Snes9x when it is not the active window");
|
||||||
AddBoolC("CustomRomOpenDialog", GUI.CustomRomOpen, false, "false to use standard Windows open dialog for the ROM open dialog");
|
AddBoolC("CustomRomOpenDialog", GUI.CustomRomOpen, false, "false to use standard Windows open dialog for the ROM open dialog");
|
||||||
AddBoolC("AddToRegistry", GUI.AddToRegistry, false, "true to add entries to registry for file type associations");
|
AddBoolC("AddToRegistry", GUI.AddToRegistry, true, "true to ask to add entries to registry for file type associations");
|
||||||
AddBoolC("AVIHiRes", GUI.AVIHiRes, false, "true to record AVI in Hi-Res scale");
|
AddBoolC("AVIHiRes", GUI.AVIHiRes, false, "true to record AVI in Hi-Res scale");
|
||||||
AddBoolC("ConfirmSaveLoad", GUI.ConfirmSaveLoad, false, "true to ask for confirmation when saving/loading");
|
AddBoolC("ConfirmSaveLoad", GUI.ConfirmSaveLoad, false, "true to ask for confirmation when saving/loading");
|
||||||
// AddUIntC("Language", GUI.Language, 0, "0=English, 1=Nederlands"); // NYI
|
// AddUIntC("Language", GUI.Language, 0, "0=English, 1=Nederlands"); // NYI
|
||||||
|
|
|
@ -2721,6 +2721,7 @@ void S9xExtraUsage ()
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "-fullscreen Start in fullscreen mode");
|
S9xMessage(S9X_INFO, S9X_USAGE, "-fullscreen Start in fullscreen mode");
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "-hidemenu Initially hide the GUI menu");
|
S9xMessage(S9X_INFO, S9X_USAGE, "-hidemenu Initially hide the GUI menu");
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "-restore Reset all settings to default");
|
S9xMessage(S9X_INFO, S9X_USAGE, "-restore Reset all settings to default");
|
||||||
|
S9xMessage(S9X_INFO, S9X_USAGE, "-removeregistrykeys Remove registry keys");
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "-cartb <filename> Specify the second cart for multicart, also triggers multicart");
|
S9xMessage(S9X_INFO, S9X_USAGE, "-cartb <filename> Specify the second cart for multicart, also triggers multicart");
|
||||||
MessageBox(NULL, _T("Snes9x command line options have been written to stdout.txt in the same folder as snes9x.exe"), _T("Command line options"), MB_OK | MB_ICONINFORMATION);
|
MessageBox(NULL, _T("Snes9x command line options have been written to stdout.txt in the same folder as snes9x.exe"), _T("Command line options"), MB_OK | MB_ICONINFORMATION);
|
||||||
}
|
}
|
||||||
|
@ -3240,8 +3241,6 @@ int WINAPI WinMain(
|
||||||
|
|
||||||
DWORD wSoundTimerRes;
|
DWORD wSoundTimerRes;
|
||||||
|
|
||||||
LoadExts();
|
|
||||||
|
|
||||||
WinRegisterConfigItems ();
|
WinRegisterConfigItems ();
|
||||||
|
|
||||||
ConfigFile::SetAlphaSort(false);
|
ConfigFile::SetAlphaSort(false);
|
||||||
|
@ -3251,6 +3250,8 @@ int WINAPI WinMain(
|
||||||
WinSaveConfigFile ();
|
WinSaveConfigFile ();
|
||||||
WinLockConfigFile ();
|
WinLockConfigFile ();
|
||||||
|
|
||||||
|
LoadExts();
|
||||||
|
|
||||||
ControllerOptionsFromControllers();
|
ControllerOptionsFromControllers();
|
||||||
ChangeInputDevice();
|
ChangeInputDevice();
|
||||||
|
|
||||||
|
@ -7015,6 +7016,32 @@ void SetInfoDlgColor(unsigned char r, unsigned char g, unsigned char b)
|
||||||
return false;\
|
return false;\
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void S9xWinRemoveRegistryKeys() {
|
||||||
|
TCHAR szRegKey[4096] = {};
|
||||||
|
|
||||||
|
_stprintf_s(szRegKey, 4095, TEXT("Software\\Classes\\%s"), SNES9XWPROGID);
|
||||||
|
SHDeleteKey(HKEY_CURRENT_USER, szRegKey);
|
||||||
|
_stprintf_s(szRegKey, 4095, TEXT("Software\\RegisteredApplications\\%s"), SNES9XWPROGID);
|
||||||
|
SHDeleteKey(HKEY_CURRENT_USER, szRegKey);
|
||||||
|
_stprintf_s(szRegKey, 4095, TEXT("Software\\Snes9x"), SNES9XWPROGID);
|
||||||
|
SHDeleteKey(HKEY_CURRENT_USER, szRegKey);
|
||||||
|
|
||||||
|
const TCHAR* szExeNames[] = { TEXT("snes9x.exe"), TEXT("snes9x-debug.exe"), TEXT("snes9x-x64.exe"), TEXT("snes9x-debug-x64.exe") };
|
||||||
|
for (auto& szExeName : szExeNames)
|
||||||
|
{
|
||||||
|
_stprintf_s(szRegKey, 4095, TEXT("Software\\Classes\\Applications\\%s"), szExeName);
|
||||||
|
SHDeleteKey(HKEY_CURRENT_USER, szRegKey);
|
||||||
|
|
||||||
|
ExtList* curr = valid_ext;
|
||||||
|
while (curr->next != NULL) {
|
||||||
|
auto ext = curr->extension;
|
||||||
|
_stprintf(szRegKey, TEXT("Software\\Classes\\.%s\\OpenWithList\\%s"), ext, szExeName);
|
||||||
|
SHDeleteKey(HKEY_CURRENT_USER, szRegKey);
|
||||||
|
curr = curr->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool RegisterProgid() {
|
bool RegisterProgid() {
|
||||||
LONG regResult;
|
LONG regResult;
|
||||||
TCHAR szRegKey[PATH_MAX];
|
TCHAR szRegKey[PATH_MAX];
|
||||||
|
@ -7190,10 +7217,21 @@ void LoadExts(void)
|
||||||
delete curr;
|
delete curr;
|
||||||
|
|
||||||
if (GUI.AddToRegistry)
|
if (GUI.AddToRegistry)
|
||||||
|
{
|
||||||
|
auto result = MessageBox(
|
||||||
|
GUI.hWnd,
|
||||||
|
TEXT("Snes9x would like to add entries to the Windows registry to set file associations and configure the jump list. Is this okay?"),
|
||||||
|
TEXT("Snes9x"),
|
||||||
|
MB_YESNO | MB_ICONQUESTION);
|
||||||
|
|
||||||
|
if (result == IDYES)
|
||||||
{
|
{
|
||||||
RegisterProgid();
|
RegisterProgid();
|
||||||
RegisterExts();
|
RegisterExts();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GUI.AddToRegistry = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MakeExtFile(void)
|
void MakeExtFile(void)
|
||||||
|
|
|
@ -464,5 +464,6 @@ void FreezeUnfreezeDialog(bool8 freeze);
|
||||||
void FreezeUnfreezeDialogPreview(bool8 freeze);
|
void FreezeUnfreezeDialogPreview(bool8 freeze);
|
||||||
void FreezeUnfreeze(const char *filename, bool8 freeze);
|
void FreezeUnfreeze(const char *filename, bool8 freeze);
|
||||||
bool UnfreezeScreenshotSlot(int slot, uint16 **image_buffer, int &width, int &height);
|
bool UnfreezeScreenshotSlot(int slot, uint16 **image_buffer, int &width, int &height);
|
||||||
|
void S9xWinRemoveRegistryKeys();
|
||||||
|
|
||||||
#endif // !defined(SNES9X_H_INCLUDED)
|
#endif // !defined(SNES9X_H_INCLUDED)
|
||||||
|
|
Loading…
Reference in New Issue