Merge pull request #5099 from JosJuice/wii-menu-strings

Display nicer version strings for the Wii Menu
This commit is contained in:
Matthew Parlane
2017-03-20 14:03:04 +13:00
committed by GitHub
6 changed files with 95 additions and 28 deletions

View File

@ -18,6 +18,23 @@ bool IsNTSC(Region region)
// Increment CACHE_REVISION (ISOFile.cpp & GameFile.cpp) if the code below is modified
Country TypicalCountryForRegion(Region region)
{
switch (region)
{
case Region::NTSC_J:
return Country::COUNTRY_JAPAN;
case Region::NTSC_U:
return Country::COUNTRY_USA;
case Region::PAL:
return Country::COUNTRY_EUROPE;
case Region::NTSC_K:
return Country::COUNTRY_KOREA;
default:
return Country::COUNTRY_UNKNOWN;
}
}
Region RegionSwitchGC(u8 country_code)
{
Region region = RegionSwitchWii(country_code);
@ -124,20 +141,79 @@ Country CountrySwitch(u8 country_code)
}
}
u8 GetSysMenuRegion(u16 title_version)
Region GetSysMenuRegion(u16 title_version)
{
if (title_version == 33)
return Region::UNKNOWN_REGION; // 1.0 uses 33 as the version number in all regions
switch (title_version & 0xf)
{
case 0:
return 'J';
return Region::NTSC_J;
case 1:
return 'E';
return Region::NTSC_U;
case 2:
return 'P';
return Region::PAL;
case 6:
return 'K';
return Region::NTSC_K;
default:
return 'A';
return Region::UNKNOWN_REGION;
}
}
std::string GetSysMenuVersionString(u16 title_version)
{
if (title_version == 33)
return "1.0"; // 1.0 uses 33 as the version number in all regions
std::string region_letter;
switch (GetSysMenuRegion(title_version))
{
case Region::NTSC_J:
region_letter = "J";
break;
case Region::NTSC_U:
region_letter = "U";
break;
case Region::PAL:
region_letter = "E";
break;
case Region::NTSC_K:
region_letter = "K";
break;
}
switch (title_version & ~0xf)
{
case 96:
case 128:
return "2.0" + region_letter;
case 160:
return "2.1" + region_letter;
case 192:
return "2.2" + region_letter;
case 224:
return "3.0" + region_letter;
case 256:
return "3.1" + region_letter;
case 288:
return "3.2" + region_letter;
case 320:
case 352:
return "3.3" + region_letter;
case 384:
return (region_letter != "K" ? "3.4" : "3.5") + region_letter;
case 416:
return "4.0" + region_letter;
case 448:
return "4.1" + region_letter;
case 480:
return "4.2" + region_letter;
case 512:
return "4.3" + region_letter;
default:
return "?.?" + region_letter;
}
}

View File

@ -4,6 +4,8 @@
#pragma once
#include <string>
#include "Common/CommonTypes.h"
namespace DiscIO
@ -67,9 +69,11 @@ enum class Language
};
bool IsNTSC(Region region);
Country TypicalCountryForRegion(Region region);
Region RegionSwitchGC(u8 country_code);
Region RegionSwitchWii(u8 country_code);
Country CountrySwitch(u8 country_code);
u8 GetSysMenuRegion(u16 title_version);
Region GetSysMenuRegion(u16 title_version);
std::string GetSysMenuVersionString(u16 title_version);
std::string GetCompanyFromID(const std::string& company_id);
}

View File

@ -78,7 +78,7 @@ Country CVolumeWAD::GetCountry() const
u8 country_code = static_cast<u8>(m_tmd.GetTitleId() & 0xff);
if (country_code == 2) // SYSMENU
country_code = GetSysMenuRegion(m_tmd.GetTitleVersion());
return TypicalCountryForRegion(GetSysMenuRegion(m_tmd.GetTitleVersion()));
return CountrySwitch(country_code);
}

View File

@ -174,22 +174,10 @@ Country CVolumeWiiCrypted::GetCountry() const
const Region region = GetRegion();
if (RegionSwitchWii(country_byte) == region)
return CountrySwitch(country_byte);
if (RegionSwitchWii(country_byte) != region)
return TypicalCountryForRegion(region);
switch (region)
{
case Region::NTSC_J:
return Country::COUNTRY_JAPAN;
case Region::NTSC_U:
return Country::COUNTRY_USA;
case Region::PAL:
return Country::COUNTRY_EUROPE;
case Region::NTSC_K:
return Country::COUNTRY_KOREA;
default:
return Country::COUNTRY_UNKNOWN;
}
return CountrySwitch(country_byte);
}
std::string CVolumeWiiCrypted::GetMakerID() const