* Split NoDisc settings in two distinct options to prevent confusion.

* Hide DM config v2 settings when using config v1
This commit is contained in:
Cyan 2012-07-22 17:08:54 +00:00
parent 6ed3f4e59f
commit 07e916bf5c
9 changed files with 74 additions and 27 deletions

View File

@ -2,8 +2,8 @@
<app version="1"> <app version="1">
<name> USB Loader GX</name> <name> USB Loader GX</name>
<coder>USB Loader GX Team</coder> <coder>USB Loader GX Team</coder>
<version>3.0 r1198</version> <version>3.0 r1199</version>
<release_date>201207201652</release_date> <release_date>201207211037</release_date>
<!-- // remove this line to enable arguments <!-- // remove this line to enable arguments
<arguments> <arguments>
<arg>--ios=250</arg> <arg>--ios=250</arg>

View File

@ -35,25 +35,25 @@ enum DMLConfig
DML_CFG_CHEAT_PATH = (1<<6), DML_CFG_CHEAT_PATH = (1<<6),
DML_CFG_ACTIVITY_LED = (1<<7), DML_CFG_ACTIVITY_LED = (1<<7),
DML_CFG_PADHOOK = (1<<8), DML_CFG_PADHOOK = (1<<8),
DML_CFG_NODISC = (1<<9), // unused since DML v1.0, removed in v2.1 DML_CFG_NODISC = (1<<9), // unused since DML v1.0, removed in v2.1
DML_CFG_FORCE_WIDE = (1<<9), // DM v2.1+, Config v02 DML_CFG_FORCE_WIDE = (1<<9), // DM v2.1+, Config v02
DML_CFG_BOOT_DISC = (1<<10), DML_CFG_BOOT_DISC = (1<<10),
// DML_CFG_BOOT_DOL = (1<<11), // unused since DML v1.0, removed in v2.1 // DML_CFG_BOOT_DOL = (1<<11), // unused since DML v1.0, removed in v2.1
DML_CFG_BOOT_DISC2 = (1<<11), // DM v2.1+, Config v02 DML_CFG_BOOT_DISC2 = (1<<11), // DM v2.1+, Config v02
DML_CFG_NODISC2 = (1<<12) // added back in DM v2.2 update2 (r20) DML_CFG_NODISC2 = (1<<12) // added back in DM v2.2 update2 (r20)
}; };
enum DMLVideoModes enum DMLVideoModes
{ {
DML_VID_DML_AUTO = (0<<16), DML_VID_DML_AUTO = (0<<16),
DML_VID_FORCE = (1<<16), DML_VID_FORCE = (1<<16),
DML_VID_NONE = (2<<16), DML_VID_NONE = (2<<16),
DML_VID_FORCE_PAL50 = (1<<0), DML_VID_FORCE_PAL50 = (1<<0),
DML_VID_FORCE_PAL60 = (1<<1), DML_VID_FORCE_PAL60 = (1<<1),
DML_VID_FORCE_NTSC = (1<<2), DML_VID_FORCE_NTSC = (1<<2),
DML_VID_FORCE_PROG = (1<<3), DML_VID_FORCE_PROG = (1<<3),
DML_VID_PROG_PATCH = (1<<4) DML_VID_PROG_PATCH = (1<<4)
}; };

View File

@ -211,6 +211,7 @@ bool CGameSettings::Save()
fprintf(f, "DMLActivityLED:%d; ", GameList[i].DMLActivityLED); fprintf(f, "DMLActivityLED:%d; ", GameList[i].DMLActivityLED);
fprintf(f, "DMLPADHOOK:%d; ", GameList[i].DMLPADHOOK); fprintf(f, "DMLPADHOOK:%d; ", GameList[i].DMLPADHOOK);
fprintf(f, "DMLNoDisc:%d; ", GameList[i].DMLNoDisc); fprintf(f, "DMLNoDisc:%d; ", GameList[i].DMLNoDisc);
fprintf(f, "DMLNoDisc2:%d; ", GameList[i].DMLNoDisc2);
fprintf(f, "DMLWidescreen:%d; ", GameList[i].DMLWidescreen); fprintf(f, "DMLWidescreen:%d; ", GameList[i].DMLWidescreen);
fprintf(f, "DMLDebug:%d; ", GameList[i].DMLDebug); fprintf(f, "DMLDebug:%d; ", GameList[i].DMLDebug);
fprintf(f, "DEVOMCEmulation:%d; ", GameList[i].DEVOMCEmulation); fprintf(f, "DEVOMCEmulation:%d; ", GameList[i].DEVOMCEmulation);
@ -354,6 +355,11 @@ bool CGameSettings::SetSetting(GameCFG & game, const char *name, const char *val
game.DMLNoDisc = atoi(value); game.DMLNoDisc = atoi(value);
return true; return true;
} }
else if(strcmp(name, "DMLNoDisc2") == 0)
{
game.DMLNoDisc2 = atoi(value);
return true;
}
else if(strcmp(name, "DMLWidescreen") == 0) else if(strcmp(name, "DMLWidescreen") == 0)
{ {
game.DMLWidescreen = atoi(value); game.DMLWidescreen = atoi(value);
@ -495,6 +501,7 @@ void CGameSettings::SetDefault(GameCFG &game)
game.DMLActivityLED = INHERIT; game.DMLActivityLED = INHERIT;
game.DMLPADHOOK = INHERIT; game.DMLPADHOOK = INHERIT;
game.DMLNoDisc = INHERIT; game.DMLNoDisc = INHERIT;
game.DMLNoDisc2 = INHERIT;
game.DMLWidescreen = INHERIT; game.DMLWidescreen = INHERIT;
game.DMLDebug = INHERIT; game.DMLDebug = INHERIT;
game.DEVOMCEmulation = INHERIT; game.DEVOMCEmulation = INHERIT;

View File

@ -35,6 +35,7 @@ typedef struct _GameCFG
short DMLActivityLED; short DMLActivityLED;
short DMLPADHOOK; short DMLPADHOOK;
short DMLNoDisc; short DMLNoDisc;
short DMLNoDisc2;
short DMLWidescreen; short DMLWidescreen;
short DMLDebug; short DMLDebug;
short DEVOMCEmulation; short DEVOMCEmulation;
@ -68,6 +69,7 @@ typedef struct _GameCFG
this->DMLActivityLED = game.DMLActivityLED; this->DMLActivityLED = game.DMLActivityLED;
this->DMLPADHOOK = game.DMLPADHOOK; this->DMLPADHOOK = game.DMLPADHOOK;
this->DMLNoDisc = game.DMLNoDisc; this->DMLNoDisc = game.DMLNoDisc;
this->DMLNoDisc2 = game.DMLNoDisc2;
this->DMLWidescreen = game.DMLWidescreen; this->DMLWidescreen = game.DMLWidescreen;
this->DMLDebug = game.DMLDebug; this->DMLDebug = game.DMLDebug;
this->DEVOMCEmulation = game.DEVOMCEmulation; this->DEVOMCEmulation = game.DEVOMCEmulation;

View File

@ -173,6 +173,7 @@ void CSettings::SetDefault()
DMLActivityLED = OFF; DMLActivityLED = OFF;
DMLPADHOOK = OFF; DMLPADHOOK = OFF;
DMLNoDisc = OFF; DMLNoDisc = OFF;
DMLNoDisc2 = OFF;
DMLWidescreen = OFF; DMLWidescreen = OFF;
DMLDebug = OFF; DMLDebug = OFF;
DEVOMCEmulation = OFF; DEVOMCEmulation = OFF;
@ -397,6 +398,7 @@ bool CSettings::Save()
fprintf(file, "DMLActivityLED = %d\n", DMLActivityLED); fprintf(file, "DMLActivityLED = %d\n", DMLActivityLED);
fprintf(file, "DMLPADHOOK = %d\n", DMLPADHOOK); fprintf(file, "DMLPADHOOK = %d\n", DMLPADHOOK);
fprintf(file, "DMLNoDisc = %d\n", DMLNoDisc); fprintf(file, "DMLNoDisc = %d\n", DMLNoDisc);
fprintf(file, "DMLNoDisc2 = %d\n", DMLNoDisc2);
fprintf(file, "DMLWidescreen = %d\n", DMLWidescreen); fprintf(file, "DMLWidescreen = %d\n", DMLWidescreen);
fprintf(file, "DMLDebug = %d\n", DMLDebug); fprintf(file, "DMLDebug = %d\n", DMLDebug);
fprintf(file, "DEVOMCEmulation = %d\n", DEVOMCEmulation); fprintf(file, "DEVOMCEmulation = %d\n", DEVOMCEmulation);
@ -819,6 +821,11 @@ bool CSettings::SetSetting(char *name, char *value)
DMLNoDisc = atoi(value); DMLNoDisc = atoi(value);
return true; return true;
} }
else if (strcmp(name, "DMLNoDisc2") == 0)
{
DMLNoDisc2 = atoi(value);
return true;
}
else if (strcmp(name, "DMLWidescreen") == 0) else if (strcmp(name, "DMLWidescreen") == 0)
{ {
DMLWidescreen = atoi(value); DMLWidescreen = atoi(value);

View File

@ -175,6 +175,7 @@ class CSettings
short DMLActivityLED; short DMLActivityLED;
short DMLPADHOOK; short DMLPADHOOK;
short DMLNoDisc; short DMLNoDisc;
short DMLNoDisc2;
short DMLWidescreen; short DMLWidescreen;
short DMLDebug; short DMLDebug;
short DEVOMCEmulation; short DEVOMCEmulation;

View File

@ -157,7 +157,10 @@ void GCGameLoadSM::SetOptionNames()
Options->SetName(Idx++, "%s", tr( "DML LED Activity" )); Options->SetName(Idx++, "%s", tr( "DML LED Activity" ));
Options->SetName(Idx++, "%s", tr( "DML PAD Hook" )); Options->SetName(Idx++, "%s", tr( "DML PAD Hook" ));
Options->SetName(Idx++, "%s", tr( "DML No Disc" )); Options->SetName(Idx++, "%s", tr( "DML No Disc" ));
Options->SetName(Idx++, "%s", tr( "DML Force Widescreen" )); if(Settings.DMLConfigVersion > 1)
Options->SetName(Idx++, "%s", tr( "DML No Disc+" ));
if(Settings.DMLConfigVersion > 1)
Options->SetName(Idx++, "%s", tr( "DML Force Widescreen" ));
Options->SetName(Idx++, "%s", tr( "DML Debug" )); Options->SetName(Idx++, "%s", tr( "DML Debug" ));
Options->SetName(Idx++, "%s", tr( "DEVO MemCard Emulation" )); Options->SetName(Idx++, "%s", tr( "DEVO MemCard Emulation" ));
} }
@ -228,11 +231,23 @@ void GCGameLoadSM::SetOptionValues()
else else
Options->SetValue(Idx++, "%s", tr(OnOffText[GameConfig.DMLNoDisc])); Options->SetValue(Idx++, "%s", tr(OnOffText[GameConfig.DMLNoDisc]));
//! Settings: DML Extended No Disc
if(Settings.DMLConfigVersion > 1)
{
if(GameConfig.DMLNoDisc2 == INHERIT)
Options->SetValue(Idx++, tr("Use global"));
else
Options->SetValue(Idx++, "%s", tr(OnOffText[GameConfig.DMLNoDisc2]));
}
//! Settings: DML Force Widescreen //! Settings: DML Force Widescreen
if(GameConfig.DMLWidescreen == INHERIT) if(Settings.DMLConfigVersion > 1)
Options->SetValue(Idx++, tr("Use global")); {
else if(GameConfig.DMLWidescreen == INHERIT)
Options->SetValue(Idx++, "%s", tr(OnOffText[GameConfig.DMLWidescreen])); Options->SetValue(Idx++, tr("Use global"));
else
Options->SetValue(Idx++, "%s", tr(OnOffText[GameConfig.DMLWidescreen]));
}
//! Settings: DML Debug //! Settings: DML Debug
if(GameConfig.DMLDebug == INHERIT) if(GameConfig.DMLDebug == INHERIT)
@ -344,8 +359,14 @@ int GCGameLoadSM::GetMenuInternal()
if (++GameConfig.DMLNoDisc >= MAX_ON_OFF) GameConfig.DMLNoDisc = INHERIT; if (++GameConfig.DMLNoDisc >= MAX_ON_OFF) GameConfig.DMLNoDisc = INHERIT;
} }
//! Settings: DML Extended No Disc
else if (Settings.DMLConfigVersion > 1 && ret == ++Idx)
{
if (++GameConfig.DMLNoDisc2 >= MAX_ON_OFF) GameConfig.DMLNoDisc2 = INHERIT;
}
//! Settings: DML Force Widescreen //! Settings: DML Force Widescreen
else if (ret == ++Idx) else if (Settings.DMLConfigVersion > 1 && ret == ++Idx)
{ {
if (++GameConfig.DMLWidescreen >= MAX_ON_OFF) GameConfig.DMLWidescreen = INHERIT; if (++GameConfig.DMLWidescreen >= MAX_ON_OFF) GameConfig.DMLWidescreen = INHERIT;
} }

View File

@ -173,6 +173,7 @@ LoaderSettings::LoaderSettings()
Options->SetName(Idx++, "%s", tr( "DML LED Activity" )); Options->SetName(Idx++, "%s", tr( "DML LED Activity" ));
Options->SetName(Idx++, "%s", tr( "DML PAD Hook" )); Options->SetName(Idx++, "%s", tr( "DML PAD Hook" ));
Options->SetName(Idx++, "%s", tr( "DML No Disc" )); Options->SetName(Idx++, "%s", tr( "DML No Disc" ));
Options->SetName(Idx++, "%s", tr( "DML No Disc+" ));
Options->SetName(Idx++, "%s", tr( "DML Force Widescreen" )); Options->SetName(Idx++, "%s", tr( "DML Force Widescreen" ));
Options->SetName(Idx++, "%s", tr( "DML Debug" )); Options->SetName(Idx++, "%s", tr( "DML Debug" ));
Options->SetName(Idx++, "%s", tr( "DEVO MemCard Emulation" )); Options->SetName(Idx++, "%s", tr( "DEVO MemCard Emulation" ));
@ -284,6 +285,9 @@ void LoaderSettings::SetOptionValues()
//! Settings: DML No Disc //! Settings: DML No Disc
Options->SetValue(Idx++, "%s", tr(OnOffText[Settings.DMLNoDisc])); Options->SetValue(Idx++, "%s", tr(OnOffText[Settings.DMLNoDisc]));
//! Settings: DML Extended No Disc
Options->SetValue(Idx++, "%s", tr(OnOffText[Settings.DMLNoDisc2]));
//! Settings: DML Force Widescreen //! Settings: DML Force Widescreen
Options->SetValue(Idx++, "%s", tr(OnOffText[Settings.DMLWidescreen])); Options->SetValue(Idx++, "%s", tr(OnOffText[Settings.DMLWidescreen]));
@ -477,6 +481,12 @@ int LoaderSettings::GetMenuInternal()
if (++Settings.DMLNoDisc >= MAX_ON_OFF) Settings.DMLNoDisc = 0; if (++Settings.DMLNoDisc >= MAX_ON_OFF) Settings.DMLNoDisc = 0;
} }
//! Settings: DML Extended No Disc
else if (ret == ++Idx)
{
if (++Settings.DMLNoDisc2 >= MAX_ON_OFF) Settings.DMLNoDisc2 = 0;
}
//! Settings: DML Force Widescreen //! Settings: DML Force Widescreen
else if (ret == ++Idx) else if (ret == ++Idx)
{ {

View File

@ -82,6 +82,7 @@ int GameBooter::BootGCMode(struct discHdr *gameHdr)
u8 dmlActivityLEDChoice = game_cfg->DMLActivityLED == INHERIT ? Settings.DMLActivityLED : game_cfg->DMLActivityLED; u8 dmlActivityLEDChoice = game_cfg->DMLActivityLED == INHERIT ? Settings.DMLActivityLED : game_cfg->DMLActivityLED;
u8 dmlPADHookChoice = game_cfg->DMLPADHOOK == INHERIT ? Settings.DMLPADHOOK : game_cfg->DMLPADHOOK; u8 dmlPADHookChoice = game_cfg->DMLPADHOOK == INHERIT ? Settings.DMLPADHOOK : game_cfg->DMLPADHOOK;
u8 dmlNoDiscChoice = game_cfg->DMLNoDisc == INHERIT ? Settings.DMLNoDisc : game_cfg->DMLNoDisc; u8 dmlNoDiscChoice = game_cfg->DMLNoDisc == INHERIT ? Settings.DMLNoDisc : game_cfg->DMLNoDisc;
u8 dmlNoDisc2Choice = game_cfg->DMLNoDisc2 == INHERIT ? Settings.DMLNoDisc2 : game_cfg->DMLNoDisc2;
u8 dmlWidescreenChoice = game_cfg->DMLWidescreen == INHERIT ? Settings.DMLWidescreen : game_cfg->DMLWidescreen; u8 dmlWidescreenChoice = game_cfg->DMLWidescreen == INHERIT ? Settings.DMLWidescreen : game_cfg->DMLWidescreen;
u8 dmlDebugChoice = game_cfg->DMLDebug == INHERIT ? Settings.DMLDebug : game_cfg->DMLDebug; u8 dmlDebugChoice = game_cfg->DMLDebug == INHERIT ? Settings.DMLDebug : game_cfg->DMLDebug;
u8 devoMCEmulation = game_cfg->DEVOMCEmulation == INHERIT ? Settings.DEVOMCEmulation : game_cfg->DEVOMCEmulation; u8 devoMCEmulation = game_cfg->DEVOMCEmulation == INHERIT ? Settings.DEVOMCEmulation : game_cfg->DEVOMCEmulation;
@ -289,7 +290,7 @@ int GameBooter::BootGCMode(struct discHdr *gameHdr)
WindowPrompt(tr("Warning:"), tr("The Force Widescreen setting requires DIOS MIOS v2.2 or more. This setting will be ignored."), tr("OK")); WindowPrompt(tr("Warning:"), tr("The Force Widescreen setting requires DIOS MIOS v2.2 or more. This setting will be ignored."), tr("OK"));
dmlWidescreenChoice = OFF; dmlWidescreenChoice = OFF;
} }
if(dmlNoDiscChoice && dmlConfigVersionChoice < 2) // DML NoDisc setting : removed in DM 1.0, config v1. Used as ForceWidescreen in DM v2.1 with cfg v1. Added back in DM 2.2 update2 Config v2 if(dmlNoDiscChoice) // DML NoDisc setting : removed in DM 1.0, config v1. Used as ForceWidescreen in DM v2.1 with cfg v1. Added back in DM 2.2 update2 Config v2
{ {
WindowPrompt(tr("Warning:"), tr("The No Disc setting is not used anymore by DIOS MIOS (Lite). Now you need to place a disc in your drive."), tr("OK")); WindowPrompt(tr("Warning:"), tr("The No Disc setting is not used anymore by DIOS MIOS (Lite). Now you need to place a disc in your drive."), tr("OK"));
} }
@ -324,14 +325,12 @@ int GameBooter::BootGCMode(struct discHdr *gameHdr)
{ {
dml_config->Config |= DML_CFG_GAME_PATH; dml_config->Config |= DML_CFG_GAME_PATH;
strncpy(dml_config->GamePath, gamePath, sizeof(dml_config->GamePath)); strncpy(dml_config->GamePath, gamePath, sizeof(dml_config->GamePath));
// use no disc patch // NoDisc patch
if(dmlNoDiscChoice) if(dmlNoDiscChoice && dmlConfigVersionChoice < 2)
{ dml_config->Config |= DML_CFG_NODISC; // used by v2.1 as ForceWidescreen setting
if(dmlConfigVersionChoice < 2) // Extended NoDisc patch
dml_config->Config |= DML_CFG_NODISC; // used by v2.1 as ForceWidescreen setting if(dmlNoDisc2Choice && dmlConfigVersionChoice > 1)
else dml_config->Config |= DML_CFG_NODISC2; // used by v2.2 update2+ as an Extended NoDisc patching
dml_config->Config |= DML_CFG_NODISC2; // used by v2.2 update2+ as NoDisc setting
}
gprintf("DML: Loading game %s\n", dml_config->GamePath); gprintf("DML: Loading game %s\n", dml_config->GamePath);
} }