-cleaned up gametdb code

-fixed gametdb memory management, now you can reload cache as
often as you want, read synopsis as often as you want without
wiiflow codedumping or freezing anymore after a few
This commit is contained in:
fix94.1 2012-11-03 23:38:39 +00:00
parent 9665ea5dc7
commit c08a0710ce
5 changed files with 413 additions and 537 deletions

View File

@ -31,7 +31,7 @@
#include "text.hpp"
#include "config/config.hpp"
#include "gecko/gecko.h"
#include "memory/mem2.hpp"
#define NAME_OFFSET_DB "gametdb_offsets.bin"
#define MAXREADSIZE 1024*1024 //Cache size only for parsing the offsets: 1MB
@ -54,12 +54,12 @@ static const ReplaceStruct Replacements[] =
};
GameTDB::GameTDB()
: isLoaded(false), isParsed(false), file(0), filepath(0), LangCode("EN"), GameNodeCache(0)
: isLoaded(false), isParsed(false), file(0), filepath(0), LangCode("EN"), GameNodeCache(NULL)
{
}
GameTDB::GameTDB(const char *filepath)
: isLoaded(false), isParsed(false), file(0), filepath(0), LangCode("EN"), GameNodeCache(0)
: isLoaded(false), isParsed(false), file(0), filepath(0), LangCode("EN"), GameNodeCache(NULL)
{
OpenFile(filepath);
}
@ -108,7 +108,7 @@ void GameTDB::CloseFile()
OffsetMap.clear();
if(GameNodeCache)
delete [] GameNodeCache;
MEM2_free(GameNodeCache);
GameNodeCache = NULL;
if(file)
@ -143,7 +143,6 @@ bool GameTDB::LoadGameOffsets(const char *path)
bool result = ParseFile();
if(result)
SaveGameOffsets(OffsetDBPath.c_str());
return result;
}
@ -159,7 +158,6 @@ bool GameTDB::LoadGameOffsets(const char *path)
bool result = ParseFile();
if(result)
SaveGameOffsets(OffsetDBPath.c_str());
return result;
}
@ -171,7 +169,6 @@ bool GameTDB::LoadGameOffsets(const char *path)
bool result = ParseFile();
if(result)
SaveGameOffsets(OffsetDBPath.c_str());
return result;
}
@ -183,7 +180,6 @@ bool GameTDB::LoadGameOffsets(const char *path)
bool result = ParseFile();
if(result)
SaveGameOffsets(OffsetDBPath.c_str());
return result;
}
@ -262,13 +258,13 @@ char *GameTDB::LoadGameNode(const char *id)
if(!offset)
return NULL;
char *data = new (std::nothrow) char[offset->nodesize+1];
char *data = (char*)MEM2_alloc(offset->nodesize+1);
if(!data)
return NULL;
if((read = GetData(data, offset->gamenode, offset->nodesize)) != offset->nodesize)
{
delete [] data;
MEM2_free(data);
return NULL;
}
@ -281,23 +277,21 @@ char *GameTDB::GetGameNode(const char *id)
{
char *data = NULL;
if(GameNodeCache != 0 && strncmp(id, GameIDCache, strlen(GameIDCache)) == 0)
if(GameNodeCache != NULL && strncmp(id, GameIDCache, strlen(GameIDCache)) == 0)
{
data = new (std::nothrow) char[strlen(GameNodeCache)+1];
data = (char*)MEM2_alloc(strlen(GameNodeCache)+1);
if(data)
strcpy(data, GameNodeCache);
}
else
{
if(GameNodeCache)
delete [] GameNodeCache;
MEM2_free(GameNodeCache);
GameNodeCache = LoadGameNode(id);
if(GameNodeCache)
{
snprintf(GameIDCache, sizeof(GameIDCache), id);
data = new (std::nothrow) char[strlen(GameNodeCache)+1];
data = (char*)MEM2_alloc(strlen(GameNodeCache)+1);
if(data)
strcpy(data, GameNodeCache);
}
@ -317,7 +311,7 @@ GameOffsets *GameTDB::GetGameOffset(const char *gameID)
return 0;
}
static inline char *CleanText(char *in_text)
static inline char *CleanText(char * &in_text)
{
if(!in_text)
return NULL;
@ -409,7 +403,7 @@ bool GameTDB::ParseFile()
if(!file)
return false;
char *Line = new (std::nothrow) char[MAXREADSIZE+1];
char *Line = (char*)MEM2_alloc(MAXREADSIZE+1);
if(!Line)
return false;
@ -454,59 +448,48 @@ bool GameTDB::ParseFile()
OffsetMap[size].nodesize = (gameEndNode-gameNode);
gameNode = gameEndNode;
}
if(readnew)
continue;
currentPos += read;
}
delete [] Line;
MEM2_free(Line);
return true;
}
bool GameTDB::FindTitle(char *data, string & title, string langCode)
bool GameTDB::FindTitle(char *data, const char * &title, const string &langCode)
{
char *language = SeekLang(data, langCode.c_str());
if(!language)
if(language == NULL)
{
language = SeekLang(data, "EN");
if(!language)
if(language == NULL)
return false;
}
title = GetNodeText(language, "<title>", "</title>");
char *the_title = GetNodeText(language, "<title>", "</title>");
if(!the_title)
if(title == NULL)
return false;
char tmp[64];
strncpy(tmp, the_title, sizeof(tmp) - 1);
tmp[sizeof(tmp) - 1] = '\0';
title=tmp;
return true;
}
bool GameTDB::GetTitle(const char *id, string & title)
bool GameTDB::GetTitle(const char *id, const char * &title)
{
title = "";
if(!id)
title = NULL;
if(id == NULL)
return false;
char *data = GetGameNode(id);
if(!data)
if(data == NULL)
return false;
bool retval = FindTitle(data, title, LangCode);
delete [] data;
MEM2_free(data);
return retval;
}
bool GameTDB::GetSynopsis(const char *id, string & synopsis)
bool GameTDB::GetSynopsis(const char *id, const char * &synopsis)
{
synopsis = "";
synopsis = NULL;
if(!id)
return false;
@ -515,99 +498,73 @@ bool GameTDB::GetSynopsis(const char *id, string & synopsis)
return false;
char *language = SeekLang(data, LangCode.c_str());
if(!language)
if(language == NULL)
{
language = SeekLang(data, "EN");
if(!language)
if(language == NULL)
{
delete [] data;
MEM2_free(data);
return false;
}
}
synopsis = GetNodeText(language, "<synopsis>", "</synopsis>");
MEM2_free(data);
char *the_synopsis = GetNodeText(language, "<synopsis>", "</synopsis>");
if(!the_synopsis)
{
delete [] data;
if(synopsis == NULL)
return false;
}
synopsis = the_synopsis;
delete [] data;
return true;
}
bool GameTDB::GetRegion(const char *id, string & region)
bool GameTDB::GetRegion(const char *id, const char * &region)
{
region = "";
region = NULL;
if(!id)
return false;
char *data = GetGameNode(id);
if(!data)
return false;
region = GetNodeText(data, "<region>", "</region>");
MEM2_free(data);
char *the_region = GetNodeText(data, "<region>", "</region>");
if(!the_region)
{
delete [] data;
if(region == NULL)
return false;
}
region = the_region;
delete [] data;
return true;
}
bool GameTDB::GetDeveloper(const char *id, string & dev)
bool GameTDB::GetDeveloper(const char *id, const char * &dev)
{
dev = "";
dev = NULL;
if(id == NULL)
return false;
char *data = GetGameNode(id);
if(data == NULL)
return false;
dev = GetNodeText(data, "<developer>", "</developer>");
MEM2_free(data);
if(dev == NULL)
return false;
return true;
}
bool GameTDB::GetPublisher(const char *id, const char * &pub)
{
pub = NULL;
if(!id)
return false;
char *data = GetGameNode(id);
if(!data)
if(data == NULL)
return false;
char *the_dev = GetNodeText(data, "<developer>", "</developer>");
if(!the_dev)
{
delete [] data;
pub = GetNodeText(data, "<publisher>", "</publisher>");
MEM2_free(data);
if(pub == NULL)
return false;
}
dev = the_dev;
delete [] data;
return true;
}
bool GameTDB::GetPublisher(const char *id, string & pub)
{
pub = "";
if(!id)
return false;
char *data = GetGameNode(id);
if(!data)
return false;
char *the_pub = GetNodeText(data, "<publisher>", "</publisher>");
if(!the_pub)
{
delete [] data;
return false;
}
pub = the_pub;
delete [] data;
return true;
}
@ -623,7 +580,7 @@ u32 GameTDB::GetPublishDate(const char *id)
char *year_string = GetNodeText(data, "<date year=\"", "/>");
if(!year_string)
{
delete [] data;
MEM2_free(data);
return 0;
}
@ -634,7 +591,7 @@ u32 GameTDB::GetPublishDate(const char *id)
char *month_string = strstr(year_string, "month=\"");
if(!month_string)
{
delete [] data;
MEM2_free(data);
return 0;
}
@ -645,7 +602,7 @@ u32 GameTDB::GetPublishDate(const char *id)
char *day_string = strstr(month_string, "day=\"");
if(!day_string)
{
delete [] data;
MEM2_free(data);
return 0;
}
@ -653,60 +610,27 @@ u32 GameTDB::GetPublishDate(const char *id)
day = atoi(day_string);
delete [] data;
MEM2_free(data);
return ((year & 0xFFFF) << 16 | (month & 0xFF) << 8 | (day & 0xFF));
}
bool GameTDB::GetGenres(const char *id, string & gen)
bool GameTDB::GetGenres(const char *id, const char * &gen)
{
vector<string> genre;
gen = NULL;
gen = "";
if(!id)
if(id == NULL)
return false;
char *data = GetGameNode(id);
if(!data)
if(data == NULL)
return false;
char *the_genre = GetNodeText(data, "<genre>", "</genre>");
if(!the_genre)
{
delete [] data;
gen = GetNodeText(data, "<genre>", "</genre>");
MEM2_free(data);
if(gen == NULL)
return false;
}
u32 genre_num = 0;
const char *ptr = the_genre;
while(*ptr != '\0')
{
if(genre_num >= genre.size())
genre.resize(genre_num+1);
if(*ptr == ',' || *ptr == '/' || *ptr == ';')
{
ptr++;
while(*ptr == ' ')
ptr++;
genre_num++;
continue;
}
if(genre[genre_num].size() == 0)
genre[genre_num].push_back(toupper((int)*ptr));
else
genre[genre_num].push_back(*ptr);
++ptr;
}
genre[genre_num].push_back('\0');
delete [] data;
gen = vectorToString(genre, ", ");
return true;
}
@ -743,7 +667,7 @@ int GameTDB::GetRating(const char *id)
char *rating_text = GetNodeText(data, "<rating type=\"", "/>");
if(!rating_text)
{
delete [] data;
MEM2_free(data);
return rating;
}
@ -756,14 +680,14 @@ int GameTDB::GetRating(const char *id)
else if(strncmp(rating_text, "GRB", 4) == 0)
rating = GAMETDB_RATING_TYPE_GRB;
delete [] data;
MEM2_free(data);
return rating;
}
bool GameTDB::GetRatingValue(const char *id, string & rating_value)
bool GameTDB::GetRatingValue(const char *id, const char * &rating_value)
{
rating_value = "";
rating_value = NULL;
if(!id)
return false;
@ -774,21 +698,15 @@ bool GameTDB::GetRatingValue(const char *id, string & rating_value)
char *rating_text = GetNodeText(data, "<rating type=\"", "/>");
if(!rating_text)
{
delete [] data;
MEM2_free(data);
return false;
}
char *value_text = GetNodeText(rating_text, "value=\"", "\"");
if(!value_text)
{
delete [] data;
rating_value = GetNodeText(rating_text, "value=\"", "\"");
MEM2_free(data);
if(rating_value == NULL)
return false;
}
rating_value = value_text;
delete [] data;
return true;
}
@ -805,7 +723,7 @@ int GameTDB::GetRatingDescriptors(const char *id, vector<string> & desc_list)
char *descriptor_text = GetNodeText(data, "<descriptor>", "</rating>");
if(!descriptor_text)
{
delete [] data;
MEM2_free(data);
return -1;
}
@ -831,7 +749,7 @@ int GameTDB::GetRatingDescriptors(const char *id, vector<string> & desc_list)
++descriptor_text;
}
delete [] data;
MEM2_free(data);
return desc_list.size();
}
@ -850,7 +768,7 @@ int GameTDB::GetWifiPlayers(const char *id)
char *PlayersNode = GetNodeText(data, "<wi-fi players=\"", "\">");
if(!PlayersNode)
{
delete [] data;
MEM2_free(data);
return players;
}
@ -872,7 +790,7 @@ int GameTDB::GetWifiFeatures(const char *id, vector<string> & feat_list)
char *feature_text = GetNodeText(data, "<feature>", "</wi-fi>");
if(!feature_text)
{
delete [] data;
MEM2_free(data);
return -1;
}
@ -902,7 +820,7 @@ int GameTDB::GetWifiFeatures(const char *id, vector<string> & feat_list)
++feature_text;
}
delete [] data;
MEM2_free(data);
return feat_list.size();
}
@ -921,7 +839,7 @@ int GameTDB::GetPlayers(const char *id)
char *PlayersNode = GetNodeText(data, "<input players=\"", "\">");
if(!PlayersNode)
{
delete [] data;
MEM2_free(data);
return players;
}
@ -943,7 +861,7 @@ int GameTDB::GetAccessories(const char *id, vector<Accessory> & acc_list)
char *ControlsNode = GetNodeText(data, "<control type=\"", "</input>");
if(!ControlsNode)
{
delete [] data;
MEM2_free(data);
return -1;
}
@ -961,7 +879,7 @@ int GameTDB::GetAccessories(const char *id, vector<Accessory> & acc_list)
char *requiredField = strstr(ControlsNode, "required=\"");
if(!requiredField)
{
delete [] data;
MEM2_free(data);
return -1;
}
@ -976,7 +894,7 @@ int GameTDB::GetAccessories(const char *id, vector<Accessory> & acc_list)
list_num++;
}
delete [] data;
MEM2_free(data);
return acc_list.size();
}
@ -1010,7 +928,7 @@ u32 GameTDB::GetCaseColor(const char *id)
if(color != 0xffffffff)
gprintf("GameTDB: Found alternate color(%x) for: %s\n", color, id);
delete [] data;
MEM2_free(data);
return color;
}
@ -1031,7 +949,7 @@ int GameTDB::GetCaseVersions(const char *id)
char *PlayersNode = GetNodeText(data, "case versions=\"", "\"");
if(!PlayersNode)
{
delete [] data;
MEM2_free(data);
return altcase;
}
@ -1040,32 +958,6 @@ int GameTDB::GetCaseVersions(const char *id)
return altcase;
}
bool GameTDB::GetGameXMLInfo(const char *id, GameXMLInfo *gameInfo)
{
if(!id || !gameInfo)
return false;
gameInfo->GameID = id;
GetTitle(id, gameInfo->Title);
GetSynopsis(id, gameInfo->Synopsis);
GetRegion(id, gameInfo->Region);
GetDeveloper(id, gameInfo->Developer);
GetPublisher(id, gameInfo->Publisher);
gameInfo->PublishDate = GetPublishDate(id);
GetGenres(id, gameInfo->Genres);
gameInfo->RatingType = GetRating(id);
GetRatingValue(id, gameInfo->RatingValue);
GetRatingDescriptors(id, gameInfo->RatingDescriptors);
gameInfo->WifiPlayers = GetWifiPlayers(id);
GetWifiFeatures(id, gameInfo->WifiFeatures);
gameInfo->Players = GetPlayers(id);
GetAccessories(id, gameInfo->Accessories);
gameInfo->CaseColor = GetCaseColor(id);
return true;
}
bool GameTDB::IsLoaded()
{
return isLoaded;

View File

@ -43,27 +43,6 @@ typedef struct _Accessory
bool Required;
} Accessory;
typedef struct _GameXMLInfo
{
string GameID;
string Region;
string Title;
string Synopsis;
string Developer;
string Publisher;
unsigned int PublishDate;
string Genres;
int RatingType;
string RatingValue;
vector<string> RatingDescriptors;
int WifiPlayers;
vector<string> WifiFeatures;
int Players;
vector<Accessory> Accessories;
int CaseColor;
} GameXMLInfo;
typedef struct _GameOffsets
{
char gameID[7];
@ -73,7 +52,7 @@ typedef struct _GameOffsets
class GameTDB
{
public:
public:
//! Constructor
GameTDB();
//! Constructor
@ -93,26 +72,26 @@ class GameTDB
//! Get the current set language code
const char * GetLanguageCode() { return LangCode.c_str(); };
//! Get the title of a specific game id in the language defined in LangCode
bool GetTitle(const char * id, string & title);
bool GetTitle(const char *id, const char * &title);
//! Get the synopsis of a specific game id in the language defined in LangCode
bool GetSynopsis(const char * id, string & synopsis);
bool GetSynopsis(const char *id, const char * &synopsis);
//! Get the region of a game for a specific game id
bool GetRegion(const char * id, string & region);
bool GetRegion(const char *id, const char * &region);
//! Get the developer of a game for a specific game id
bool GetDeveloper(const char * id, string & dev);
bool GetDeveloper(const char *id, const char * &dev);
//! Get the publisher of a game for a specific game id
bool GetPublisher(const char * id, string & pub);
bool GetPublisher(const char *id, const char * &pub);
//! Get the publish date of a game for a specific game id
//! First 1 byte is the day, than 1 byte month and last 2 bytes is the year
//! year = (return >> 16), month = (return >> 8) & 0xFF, day = return & 0xFF
unsigned int GetPublishDate(const char * id);
unsigned int GetPublishDate(const char *id);
//! Get the genre list of a game for a specific game id
bool GetGenres(const char * id, string & gen);
bool GetGenres(const char * id, const char * &gen);
//! Get the rating type for a specific game id
//! The rating type can be converted to a string with GameTDB::RatingToString(rating)
int GetRating(const char * id);
//! Get the rating value for a specific game id
bool GetRatingValue(const char * id, string & rating_value);
bool GetRatingValue(const char * id, const char * &rating_value);
//! Get the rating descriptor list inside a vector for a specific game id
//! Returns the amount of descriptors found or -1 if failed
int GetRatingDescriptors(const char * id, vector<string> & desc_list);
@ -132,8 +111,6 @@ class GameTDB
//! Returns the color in RGB (first 3 bytes)
unsigned int GetCaseColor(const char * id);
int GetCaseVersions(const char * id);
//! Get the complete game info in the GameXMLInfo struct
bool GetGameXMLInfo(const char * id, GameXMLInfo * gameInfo);
//! Convert a specific game rating to a string
static const char * RatingToString(int rating);
//! Get the version of the gametdb xml database
@ -142,19 +119,19 @@ class GameTDB
inline size_t GetEntryCount() { return OffsetMap.size(); };
//! Is a database loaded
bool IsLoaded();
private:
private:
bool ParseFile();
bool LoadGameOffsets(const char * path);
bool SaveGameOffsets(const char * path);
bool CheckTitlesIni(const char * path);
bool FindTitle(char * data, string & title, string langCode);
bool FindTitle(char *data, const char * &title, const string &langCode);
unsigned int FindCaseColor(char * data);
inline int GetData(char * data, int offset, int size);
inline char * LoadGameNode(const char * id);
inline char * GetGameNode(const char * id);
inline GameOffsets * GetGameOffset(const char * id);
inline char * SeekLang(char * text, const char * langcode);
inline char * GetNodeText(char * data, const char * nodestart, const char * nodeend);
inline char * GetNodeText(char *data, const char *nodestart, const char *nodeend);
bool isLoaded;
bool isParsed;
@ -162,7 +139,7 @@ class GameTDB
FILE * file;
const char *filepath;
string LangCode;
char * GameNodeCache;
char *GameNodeCache;
char GameIDCache[7];
};

View File

@ -70,18 +70,18 @@ static void AddISO(const char *GameID, const char *GameTitle, const char *GamePa
if(GameID != NULL) strncpy(ListElement.id, GameID, 6);
if(GamePath != NULL) strncpy(ListElement.path, GamePath, sizeof(ListElement.path) - 1);
ListElement.casecolor = CustomTitles.getColor("COVERS", ListElement.id, GameColor).intVal();
string CustomTitle = CustomTitles.getString("TITLES", ListElement.id);
const char *CustomTitle = CustomTitles.getString("TITLES", ListElement.id).c_str();
if(gameTDB.IsLoaded())
{
if(ListElement.casecolor == GameColor)
ListElement.casecolor = gameTDB.GetCaseColor(ListElement.id);
if(CustomTitle.size() == 0)
gameTDB.GetTitle(ListElement.id, CustomTitle);
ListElement.wifi = gameTDB.GetWifiPlayers(ListElement.id);
ListElement.players = gameTDB.GetPlayers(ListElement.id);
if(CustomTitle == NULL || CustomTitle[0] == '\0')
gameTDB.GetTitle(ListElement.id, CustomTitle);
}
if(CustomTitle.size() > 0)
mbstowcs(ListElement.title, CustomTitle.c_str(), 63);
if(CustomTitle != NULL && CustomTitle[0] != '\0')
mbstowcs(ListElement.title, CustomTitle, 63);
else if(GameTitle != NULL)
mbstowcs(ListElement.title, GameTitle, 63);
Asciify(ListElement.title);
@ -201,18 +201,18 @@ static void Create_Channel_List()
ListElement.settings[1] = TITLE_LOWER(chan->title);
strncpy(ListElement.id, chan->id, 4);
ListElement.casecolor = CustomTitles.getColor("COVERS", ListElement.id, 1).intVal();
string CustomTitle = CustomTitles.getString("TITLES", ListElement.id);
const char *CustomTitle = CustomTitles.getString("TITLES", ListElement.id).c_str();
if(gameTDB.IsLoaded())
{
if(ListElement.casecolor == 1)
ListElement.casecolor = gameTDB.GetCaseColor(ListElement.id);
if(CustomTitle.size() == 0)
gameTDB.GetTitle(ListElement.id, CustomTitle);
ListElement.wifi = gameTDB.GetWifiPlayers(ListElement.id);
ListElement.players = gameTDB.GetPlayers(ListElement.id);
if(CustomTitle == NULL || CustomTitle[0] == '\0')
gameTDB.GetTitle(ListElement.id, CustomTitle);
}
if(CustomTitle.size() > 0)
mbstowcs(ListElement.title, CustomTitle.c_str(), 63);
if(CustomTitle != NULL && CustomTitle[0] != '\0')
mbstowcs(ListElement.title, CustomTitle, 63);
else
wcsncpy(ListElement.title, chan->name, 64);
ListElement.type = TYPE_CHANNEL;

View File

@ -1668,60 +1668,59 @@ void CMenu::_initCF(void)
if (ageLock < 19)
{
int ageRated = min(max(gameAgeList.getInt(domain, id), 0), 19);
if(ageRated == 0 && (element->type == TYPE_WII_GAME || element->type == TYPE_CHANNEL))
if(ageRated == 0 && gametdb.IsLoaded() && (element->type == TYPE_WII_GAME || element->type == TYPE_CHANNEL))
{
GameXMLInfo gameinfo;
if(gametdb.IsLoaded() && gametdb.GetGameXMLInfo(id.c_str(), &gameinfo))
const char *RatingValue = NULL;
if(gametdb.GetRatingValue(id.c_str(), RatingValue))
{
switch(gameinfo.RatingType)
switch(gametdb.GetRating(id.c_str()))
{
case GAMETDB_RATING_TYPE_CERO:
if (gameinfo.RatingValue == "A")
if(RatingValue[0] == 'A')
ageRated = 3;
else if (gameinfo.RatingValue == "B")
else if(RatingValue[0] == 'B')
ageRated = 12;
else if (gameinfo.RatingValue == "D")
else if(RatingValue[0] == 'D')
ageRated = 15;
else if (gameinfo.RatingValue == "C")
else if(RatingValue[0] == 'C')
ageRated = 17;
else if (gameinfo.RatingValue == "Z")
else if(RatingValue[0] == 'Z')
ageRated = 18;
break;
case GAMETDB_RATING_TYPE_ESRB:
if (gameinfo.RatingValue == "E")
if(RatingValue[0] == 'E')
ageRated = 6;
else if (gameinfo.RatingValue == "EC")
else if(memcmp(RatingValue, "EC", 2) == 0)
ageRated = 3;
else if (gameinfo.RatingValue == "E10+")
else if(memcmp(RatingValue, "E10+", 4) == 0)
ageRated = 10;
else if (gameinfo.RatingValue == "T")
else if(RatingValue[0] == 'T')
ageRated = 13;
else if (gameinfo.RatingValue == "M")
else if(RatingValue[0] == 'M')
ageRated = 17;
else if (gameinfo.RatingValue == "AO")
else if(memcmp(RatingValue, "AO", 2) == 0)
ageRated = 18;
break;
case GAMETDB_RATING_TYPE_PEGI:
if (gameinfo.RatingValue == "3")
if(RatingValue[0] == '3')
ageRated = 3;
else if (gameinfo.RatingValue == "7")
else if(RatingValue[0] == '7')
ageRated = 7;
else if (gameinfo.RatingValue == "12")
else if(memcmp(RatingValue, "12", 2) == 0)
ageRated = 12;
else if (gameinfo.RatingValue == "16")
else if(memcmp(RatingValue, "16", 2) == 0)
ageRated = 16;
else if (gameinfo.RatingValue == "18")
else if(memcmp(RatingValue, "18", 2) == 0)
ageRated = 18;
break;
case GAMETDB_RATING_TYPE_GRB:
if (gameinfo.RatingValue == "A")
if(RatingValue[0] == 'A')
ageRated = 3;
else if (gameinfo.RatingValue == "12")
else if(memcmp(RatingValue, "12", 2) == 0)
ageRated = 12;
else if (gameinfo.RatingValue == "15")
else if(memcmp(RatingValue, "15", 2) == 0)
ageRated = 15;
else if (gameinfo.RatingValue == "18")
else if(memcmp(RatingValue, "18", 2) == 0)
ageRated = 18;
break;
default:

View File

@ -77,11 +77,10 @@ extern const u8 pegi_12_png[];
extern const u8 pegi_16_png[];
extern const u8 pegi_18_png[];
GameXMLInfo gameinfo;
wstringEx gameinfo_Synopsis_w;
wstringEx gameinfo_Title_w;
static bool titlecheck = false;
bool titlecheck = false;
u8 cnt_controlsreq = 0, cnt_controls = 0;
const int pixels_to_skip = 10;
@ -130,7 +129,7 @@ void CMenu::_gameinfo(void)
amount_of_skips--;
}
}
else if (BTN_RIGHT_PRESSED && !(m_thrdWorking && m_thrdStop) && page == 0 && gameinfo.Synopsis.size() > 0)
else if (BTN_RIGHT_PRESSED && !(m_thrdWorking && m_thrdStop) && page == 0 && !gameinfo_Synopsis_w.empty())
{
page = 1;
amount_of_skips = 0;
@ -313,24 +312,37 @@ void CMenu::_textGameInfo(void)
GameTDB gametdb;
gametdb.OpenFile(fmt("%s/wiitdb.xml", m_settingsDir.c_str()));
gametdb.SetLanguageCode(m_loc.getString(m_curLanguage, "gametdb_code", "EN").c_str());
titlecheck = gametdb.IsLoaded() && gametdb.GetGameXMLInfo(m_cf.getId().c_str(), &gameinfo);
const char *TMP_Char = NULL;
titlecheck = gametdb.IsLoaded();
if(titlecheck)
{
gameinfo_Title_w.fromUTF8(gameinfo.Title);
char GameID[7];
GameID[6] = '\0';
strncpy(GameID, m_cf.getId().c_str(), 6);
if(gametdb.GetTitle(GameID, TMP_Char))
{
gameinfo_Title_w.fromUTF8(TMP_Char);
m_btnMgr.setText(m_gameinfoLblTitle, gameinfo_Title_w, true);
gameinfo_Synopsis_w.fromUTF8(gameinfo.Synopsis);
}
if(gametdb.GetSynopsis(GameID, TMP_Char))
{
gameinfo_Synopsis_w.fromUTF8(TMP_Char);
m_btnMgr.setText(m_gameinfoLblSynopsis, gameinfo_Synopsis_w);
}
m_btnMgr.setText(m_gameinfoLblID, wfmt(L"GameID: %s", GameID), true);
if(gametdb.GetDeveloper(GameID, TMP_Char))
m_btnMgr.setText(m_gameinfoLblDev, wfmt(_fmt("gameinfo1",L"Developer: %s"), TMP_Char), true);
if(gametdb.GetPublisher(GameID, TMP_Char))
m_btnMgr.setText(m_gameinfoLblPublisher, wfmt(_fmt("gameinfo2",L"Publisher: %s"), TMP_Char), true);
if(gametdb.GetRegion(GameID, TMP_Char))
m_btnMgr.setText(m_gameinfoLblRegion, wfmt(_fmt("gameinfo3",L"Region: %s"), TMP_Char), true);
if(gametdb.GetGenres(GameID, TMP_Char))
m_btnMgr.setText(m_gameinfoLblGenre, wfmt(_fmt("gameinfo5",L"Genre: %s"), TMP_Char), true);
m_btnMgr.setText(m_gameinfoLblID, wfmt(L"GameID: %s", gameinfo.GameID.c_str()), true);
m_btnMgr.setText(m_gameinfoLblDev, wfmt(_fmt("gameinfo1",L"Developer: %s"), gameinfo.Developer.c_str()), true);
m_btnMgr.setText(m_gameinfoLblPublisher, wfmt(_fmt("gameinfo2",L"Publisher: %s"), gameinfo.Publisher.c_str()), true);
m_btnMgr.setText(m_gameinfoLblRegion, wfmt(_fmt("gameinfo3",L"Region: %s"), gameinfo.Region.c_str()), true);
m_btnMgr.setText(m_gameinfoLblGenre, wfmt(_fmt("gameinfo5",L"Genre: %s"), gameinfo.Genres.c_str()), true);
int year = gameinfo.PublishDate >> 16;
int day = gameinfo.PublishDate & 0xFF;
int month = (gameinfo.PublishDate >> 8) & 0xFF;
int PublishDate = gametdb.GetPublishDate(GameID);
int year = PublishDate >> 16;
int day = PublishDate & 0xFF;
int month = (PublishDate >> 8) & 0xFF;
switch(CONF_GetRegion())
{
case 0:
@ -345,151 +357,153 @@ void CMenu::_textGameInfo(void)
m_btnMgr.setText(m_gameinfoLblRlsdate, wfmt(_fmt("gameinfo4",L"Release Date: %i-%i-%i"), day, month, year), true);
break;
}
//Ratings
m_rating.fromJPG(norating_jpg, norating_jpg_size);
switch(gameinfo.RatingType)
const char *RatingValue = NULL;
if(gametdb.GetRatingValue(GameID, RatingValue))
{
switch(gametdb.GetRating(GameID))
{
case GAMETDB_RATING_TYPE_CERO:
if (gameinfo.RatingValue == "A")
if(RatingValue[0] == 'A')
m_rating.fromPNG(cero_a_png);
else if (gameinfo.RatingValue == "B")
else if(RatingValue[0] == 'B')
m_rating.fromPNG(cero_b_png);
else if (gameinfo.RatingValue == "D")
else if(RatingValue[0] == 'D')
m_rating.fromPNG(cero_d_png);
else if (gameinfo.RatingValue == "C")
else if(RatingValue[0] == 'C')
m_rating.fromPNG(cero_c_png);
else if (gameinfo.RatingValue == "Z")
else if(RatingValue[0] == 'Z')
m_rating.fromPNG(cero_z_png);
break;
case GAMETDB_RATING_TYPE_ESRB:
if (gameinfo.RatingValue == "E")
if(RatingValue[0] == 'E')
m_rating.fromJPG(esrb_e_jpg, esrb_e_jpg_size);
else if (gameinfo.RatingValue == "EC")
else if(memcmp(RatingValue, "EC", 2) == 0)
m_rating.fromJPG(esrb_ec_jpg, esrb_ec_jpg_size);
else if (gameinfo.RatingValue == "E10+")
else if(memcmp(RatingValue, "E10+", 4) == 0)
m_rating.fromJPG(esrb_eten_jpg, esrb_eten_jpg_size);
else if (gameinfo.RatingValue == "T")
else if(RatingValue[0] == 'T')
m_rating.fromJPG(esrb_t_jpg, esrb_t_jpg_size);
else if (gameinfo.RatingValue == "M")
else if(RatingValue[0] == 'M')
m_rating.fromJPG(esrb_m_jpg, esrb_m_jpg_size);
else if (gameinfo.RatingValue == "AO")
else if(memcmp(RatingValue, "AO", 2) == 0)
m_rating.fromJPG(esrb_ao_jpg, esrb_ao_jpg_size);
break;
case GAMETDB_RATING_TYPE_PEGI:
if (gameinfo.RatingValue == "3")
if(RatingValue[0] == '3')
m_rating.fromPNG(pegi_3_png);
else if (gameinfo.RatingValue == "7")
else if(RatingValue[0] == '7')
m_rating.fromPNG(pegi_7_png);
else if (gameinfo.RatingValue == "12")
else if(memcmp(RatingValue, "12", 2) == 0)
m_rating.fromPNG(pegi_12_png);
else if (gameinfo.RatingValue == "16")
else if(memcmp(RatingValue, "16", 2) == 0)
m_rating.fromPNG(pegi_16_png);
else if (gameinfo.RatingValue == "18")
else if(memcmp(RatingValue, "18", 2) == 0)
m_rating.fromPNG(pegi_18_png);
break;
case GAMETDB_RATING_TYPE_GRB:
if (gameinfo.RatingValue == "A")
if(RatingValue[0] == 'A')
m_rating.fromPNG(grb_a_png);
else if (gameinfo.RatingValue == "12")
else if(memcmp(RatingValue, "12", 2) == 0)
m_rating.fromPNG(grb_12_png);
else if (gameinfo.RatingValue == "15")
else if(memcmp(RatingValue, "15", 2) == 0)
m_rating.fromPNG(grb_15_png);
else if (gameinfo.RatingValue == "18")
else if(memcmp(RatingValue, "18", 2) == 0)
m_rating.fromPNG(grb_18_png);
break;
default:
break;
}
}
m_btnMgr.setTexture(m_gameinfoLblRating, m_rating);
//Wifi players
int WifiPlayers = gametdb.GetWifiPlayers(GameID);
STexture emptyTex;
if (gameinfo.WifiPlayers == 1)
if(WifiPlayers == 1)
m_wifi.fromPNG(wifi1_png);
else if (gameinfo.WifiPlayers == 2)
else if(WifiPlayers == 2)
m_wifi.fromPNG(wifi2_png);
else if (gameinfo.WifiPlayers == 4)
else if(WifiPlayers == 4)
m_wifi.fromPNG(wifi4_png);
else if (gameinfo.WifiPlayers == 8)
else if(WifiPlayers == 8)
m_wifi.fromPNG(wifi8_png);
else if (gameinfo.WifiPlayers == 10)
else if(WifiPlayers == 10)
m_wifi.fromPNG(wifi10_png);
else if (gameinfo.WifiPlayers == 12)
else if(WifiPlayers == 12)
m_wifi.fromPNG(wifi12_png);
else if (gameinfo.WifiPlayers == 16)
else if(WifiPlayers == 16)
m_wifi.fromPNG(wifi16_png);
else if (gameinfo.WifiPlayers == 18)
else if(WifiPlayers == 18)
m_wifi.fromPNG(wifi18_png);
else if (gameinfo.WifiPlayers == 32)
else if(WifiPlayers == 32)
m_wifi.fromPNG(wifi32_png);
if(gameinfo.WifiPlayers > 0)
if(WifiPlayers > 0)
m_btnMgr.setTexture(m_gameinfoLblWifiplayers, m_wifi);
else
m_btnMgr.setTexture(m_gameinfoLblWifiplayers, emptyTex);
u8 wiimote=0,
nunchuk=0,
classiccontroller=0,
balanceboard=0,
dancepad=0,
guitar=0,
gamecube=0,
motionplus=0,
drums=0,
microphone=0,
wheel=0,
keyboard=0,
udraw = 0,
zapper=0;
//check required controlls
for (vector<Accessory>::iterator acc_itr = gameinfo.Accessories.begin(); acc_itr != gameinfo.Accessories.end(); acc_itr++)
bool wiimote = false;
bool nunchuk = false;
bool classiccontroller = false;
bool balanceboard = false;
bool dancepad = false;
bool guitar = false;
bool gamecube = false;
bool motionplus = false;
bool drums = false;
bool microphone = false;
bool wheel = false;
bool keyboard = false;
bool udraw = false;
bool zapper = false;
vector<Accessory> Accessories;
gametdb.GetAccessories(GameID, Accessories);
for(vector<Accessory>::iterator acc_itr = Accessories.begin(); acc_itr != Accessories.end(); acc_itr++)
{
if (!acc_itr->Required) continue;
if (strcmp((acc_itr->Name).c_str(), "wiimote") == 0)
wiimote=1;
else if (strcmp((acc_itr->Name).c_str(), "nunchuk") == 0)
nunchuk=1;
else if (strcmp((acc_itr->Name).c_str(), "guitar") == 0)
guitar=1;
else if (strcmp((acc_itr->Name).c_str(), "drums") == 0)
drums=1;
else if (strcmp((acc_itr->Name).c_str(), "dancepad") == 0)
dancepad=1;
else if (strcmp((acc_itr->Name).c_str(), "motionplus") == 0)
motionplus=1;
else if (strcmp((acc_itr->Name).c_str(), "microphone") == 0)
microphone=1;
else if (strcmp((acc_itr->Name).c_str(), "balanceboard") == 0)
balanceboard=1;
else if (strcmp((acc_itr->Name).c_str(), "udraw") == 0)
udraw = 1;
if(!acc_itr->Required)
continue;
if(strcmp((acc_itr->Name).c_str(), "wiimote") == 0)
wiimote = true;
else if(strcmp((acc_itr->Name).c_str(), "nunchuk") == 0)
nunchuk = true;
else if(strcmp((acc_itr->Name).c_str(), "guitar") == 0)
guitar = true;
else if(strcmp((acc_itr->Name).c_str(), "drums") == 0)
drums = true;
else if(strcmp((acc_itr->Name).c_str(), "dancepad") == 0)
dancepad = true;
else if(strcmp((acc_itr->Name).c_str(), "motionplus") == 0)
motionplus = true;
else if(strcmp((acc_itr->Name).c_str(), "microphone") == 0)
microphone = true;
else if(strcmp((acc_itr->Name).c_str(), "balanceboard") == 0)
balanceboard = true;
else if(strcmp((acc_itr->Name).c_str(), "udraw") == 0)
udraw = true;
}
u8 x = 0;
u8 max_controlsReq = ARRAY_SIZE(m_gameinfoLblControlsReq);
if(wiimote && x < max_controlsReq)
{
u8 players = gameinfo.Players;
if (gameinfo.Players >= 10)
players = players/10;
u8 players = gametdb.GetPlayers(GameID);
if(players >= 10)
players /= 10;
if (players == 1)
if(players == 1)
m_controlsreq[x].fromPNG(wiimote1_png);
else if (players == 2)
else if(players == 2)
m_controlsreq[x].fromPNG(wiimote2_png);
else if (players == 3)
else if(players == 3)
m_controlsreq[x].fromPNG(wiimote3_png);
else if (players == 4)
else if(players == 4)
m_controlsreq[x].fromPNG(wiimote4_png);
else if (players == 6)
else if(players == 6)
m_controlsreq[x].fromPNG(wiimote6_png);
else if (players == 8)
else if(players == 8)
m_controlsreq[x].fromPNG(wiimote8_png);
m_btnMgr.setTexture(m_gameinfoLblControlsReq[x] ,m_controlsreq[x], 20, 60);
@ -543,60 +557,56 @@ void CMenu::_textGameInfo(void)
m_btnMgr.setTexture(m_gameinfoLblControlsReq[x] ,m_controlsreq[x], 52, 60);
x++;
}
cnt_controlsreq = x;
//check optional controlls
wiimote=0,
nunchuk=0,
classiccontroller=0,
balanceboard=0,
dancepad=0,
guitar=0,
gamecube=0,
motionplus=0,
drums=0,
microphone=0,
wheel=0,
keyboard=0,
udraw = 0,
zapper=0;
for (vector<Accessory>::iterator acc_itr = gameinfo.Accessories.begin(); acc_itr != gameinfo.Accessories.end(); acc_itr++)
wiimote = false;
nunchuk = false;
classiccontroller = false;
balanceboard = false;
dancepad = false;
guitar = false;
gamecube = false;
motionplus = false;
drums = false;
microphone = false;
wheel = false;
keyboard = false;
udraw = false;
zapper = false;
for(vector<Accessory>::iterator acc_itr = Accessories.begin(); acc_itr != Accessories.end(); acc_itr++)
{
if (acc_itr->Required) continue;
if (strcmp((acc_itr->Name).c_str(), "classiccontroller") == 0)
classiccontroller=1;
else if (strcmp((acc_itr->Name).c_str(), "nunchuk") == 0)
nunchuk=1;
else if (strcmp((acc_itr->Name).c_str(), "guitar") == 0)
guitar=1;
else if (strcmp((acc_itr->Name).c_str(), "drums") == 0)
drums=1;
else if (strcmp((acc_itr->Name).c_str(), "dancepad") == 0)
dancepad=1;
else if (strcmp((acc_itr->Name).c_str(), "motionplus") == 0)
motionplus=1;
else if (strcmp((acc_itr->Name).c_str(), "balanceboard") == 0)
balanceboard=1;
else if (strcmp((acc_itr->Name).c_str(), "microphone") == 0)
microphone=1;
else if (strcmp((acc_itr->Name).c_str(), "gamecube") == 0)
gamecube=1;
else if (strcmp((acc_itr->Name).c_str(), "keyboard") == 0)
keyboard=1;
else if (strcmp((acc_itr->Name).c_str(), "zapper") == 0)
zapper=1;
else if (strcmp((acc_itr->Name).c_str(), "wheel") == 0)
wheel=1;
else if (strcmp((acc_itr->Name).c_str(), "udraw") == 0)
udraw = 1;
if(acc_itr->Required)
continue;
if(strcmp((acc_itr->Name).c_str(), "classiccontroller") == 0)
classiccontroller = true;
else if(strcmp((acc_itr->Name).c_str(), "nunchuk") == 0)
nunchuk = true;
else if(strcmp((acc_itr->Name).c_str(), "guitar") == 0)
guitar = true;
else if(strcmp((acc_itr->Name).c_str(), "drums") == 0)
drums = true;
else if(strcmp((acc_itr->Name).c_str(), "dancepad") == 0)
dancepad = true;
else if(strcmp((acc_itr->Name).c_str(), "motionplus") == 0)
motionplus = true;
else if(strcmp((acc_itr->Name).c_str(), "balanceboard") == 0)
balanceboard = true;
else if(strcmp((acc_itr->Name).c_str(), "microphone") == 0)
microphone = true;
else if(strcmp((acc_itr->Name).c_str(), "gamecube") == 0)
gamecube = true;
else if(strcmp((acc_itr->Name).c_str(), "keyboard") == 0)
keyboard = true;
else if(strcmp((acc_itr->Name).c_str(), "zapper") == 0)
zapper = true;
else if(strcmp((acc_itr->Name).c_str(), "wheel") == 0)
wheel = true;
else if(strcmp((acc_itr->Name).c_str(), "udraw") == 0)
udraw = true;
}
x = 0;
u8 max_controls = ARRAY_SIZE(m_gameinfoLblControls);
if(classiccontroller && x < max_controls)
{
m_controls[x].fromPNG(classiccontroller_png);
@ -675,12 +685,10 @@ void CMenu::_textGameInfo(void)
m_btnMgr.setTexture(m_gameinfoLblControls[x] ,m_controls[x], 52, 60);
x++;
}
cnt_controls = x;
}
else
m_btnMgr.setText(m_gameinfoLblTitle, wfmt(_fmt("gameinfo6",L"No Gameinfo"), true));
gametdb.CloseFile();
}