2012-01-21 21:57:41 +01:00
|
|
|
#include "cachedlist.hpp"
|
|
|
|
#include <typeinfo>
|
|
|
|
|
|
|
|
template <class T>
|
2012-02-03 04:00:13 +01:00
|
|
|
void CachedList<T>::Load(string path, string containing, string m_lastLanguage) /* Load All */
|
2012-01-21 21:57:41 +01:00
|
|
|
{
|
|
|
|
gprintf("\nLoading files containing %s in %s\n", containing.c_str(), path.c_str());
|
|
|
|
m_loaded = false;
|
|
|
|
m_database = sfmt("%s/%s.db", m_cacheDir.c_str(), (make_db_name(path)).c_str());
|
2012-03-08 13:52:01 +01:00
|
|
|
|
2012-01-21 21:57:41 +01:00
|
|
|
m_wbfsFS = strncasecmp(DeviceHandler::Instance()->PathToFSName(path.c_str()), "WBFS", 4) == 0;
|
|
|
|
|
|
|
|
bool update_games = false;
|
|
|
|
bool update_homebrew = false;
|
2012-02-01 00:44:54 +01:00
|
|
|
bool update_dml = false;
|
2012-04-08 17:54:34 +02:00
|
|
|
bool update_emu = strcasestr(containing.c_str(), ".zip") != NULL;
|
2012-02-02 02:46:01 +01:00
|
|
|
bool ditimes = false;
|
2012-02-18 14:51:55 +01:00
|
|
|
bool music = typeid(T) == typeid(std::string);
|
|
|
|
if(music)
|
|
|
|
gprintf("Loading music list from path: %s\n",path.c_str());
|
2012-04-08 17:54:34 +02:00
|
|
|
else if(update_emu)
|
|
|
|
gprintf("Loading emulator gamelist from path: %s\n",path.c_str());
|
2012-02-18 14:51:55 +01:00
|
|
|
else if(!m_wbfsFS)
|
2012-01-21 21:57:41 +01:00
|
|
|
{
|
2012-02-18 14:51:55 +01:00
|
|
|
gprintf("Database file: %s\n", m_database.c_str());
|
|
|
|
|
2012-01-21 21:57:41 +01:00
|
|
|
update_games = strcasestr(path.c_str(), "wbfs") != NULL && force_update[COVERFLOW_USB];
|
|
|
|
update_homebrew = strcasestr(path.c_str(), "apps") != NULL && force_update[COVERFLOW_HOMEBREW];
|
2012-03-08 13:52:01 +01:00
|
|
|
|
|
|
|
const char* partition = DeviceName[DeviceHandler::Instance()->PathToDriveType(path.c_str())];
|
|
|
|
update_dml = strcasestr(path.c_str(), sfmt(strncmp(partition, "sd", 2) != 0 ? m_DMLgameDir.c_str() : "%s:/games", partition).c_str()) != NULL && force_update[COVERFLOW_DML];
|
|
|
|
|
2012-04-08 17:54:34 +02:00
|
|
|
gprintf("update_games=%d update_homebrew=%d update_dml=%d, update_emu=%d\n", update_games, update_homebrew, update_dml, update_emu);
|
|
|
|
if(update_games || update_homebrew || update_dml || update_emu)
|
2012-01-21 21:57:41 +01:00
|
|
|
remove(m_database.c_str());
|
|
|
|
|
2012-02-02 02:46:01 +01:00
|
|
|
m_discinf = sfmt("%s/disc.info", path.c_str());
|
|
|
|
struct stat filestat, discinfo, cache;
|
2012-01-21 21:57:41 +01:00
|
|
|
gprintf("%s\n", path.c_str());
|
2012-02-02 02:46:01 +01:00
|
|
|
if(stat(path.c_str(), &filestat) == -1) return;
|
2012-01-21 21:57:41 +01:00
|
|
|
|
|
|
|
bool update_lang = m_lastLanguage != m_curLanguage;
|
|
|
|
bool noDB = stat(m_database.c_str(), &cache) == -1;
|
|
|
|
bool mtimes = filestat.st_mtime > cache.st_mtime;
|
2012-02-02 02:46:01 +01:00
|
|
|
if(strcasestr(m_discinf.c_str(), "wbfs") != NULL && stat(m_discinf.c_str(), &discinfo) != -1)
|
2012-04-05 13:00:05 +02:00
|
|
|
ditimes = discinfo.st_mtime > cache.st_mtime;
|
2012-01-21 21:57:41 +01:00
|
|
|
|
2012-02-02 02:46:01 +01:00
|
|
|
m_update = update_lang || noDB || mtimes || ditimes;
|
2012-02-03 04:00:13 +01:00
|
|
|
if(m_update) gprintf("Cache of %s is being updated because ", path.c_str());
|
|
|
|
if(update_lang) gprintf("languages are different!\nOld language string: %s\nNew language string: %s\n", m_lastLanguage.c_str(), m_curLanguage.c_str());
|
|
|
|
if(noDB) gprintf("a database was not found!\n");
|
2012-02-18 14:51:55 +01:00
|
|
|
if(mtimes || ditimes) gprintf("the WBFS folder was modified!\n");
|
2012-04-05 13:00:05 +02:00
|
|
|
|
|
|
|
if(m_extcheck && !m_update)
|
|
|
|
{
|
|
|
|
bool m_chupdate = false;
|
|
|
|
|
|
|
|
DIR *dir = opendir(path.c_str());
|
|
|
|
struct dirent *entry;
|
|
|
|
while((entry = readdir(dir)) != NULL)
|
|
|
|
{
|
|
|
|
m_discinf = sfmt("%s/%s", path.c_str(), entry->d_name);
|
|
|
|
if(stat(m_discinf.c_str(), &discinfo) != -1)
|
|
|
|
m_chupdate = discinfo.st_mtime > cache.st_mtime;
|
|
|
|
|
|
|
|
if(m_chupdate)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
m_update = m_chupdate;
|
|
|
|
}
|
2012-01-21 21:57:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if(update_games) force_update[COVERFLOW_USB] = false;
|
|
|
|
if(update_homebrew) force_update[COVERFLOW_HOMEBREW] = false;
|
2012-02-03 00:35:05 +01:00
|
|
|
if(update_dml) force_update[COVERFLOW_DML] = false;
|
2012-01-21 21:57:41 +01:00
|
|
|
|
2012-04-08 17:54:34 +02:00
|
|
|
if(m_update || m_wbfsFS || music || update_emu)
|
2012-01-21 21:57:41 +01:00
|
|
|
{
|
|
|
|
gprintf("Calling list to update filelist\n");
|
2012-02-02 02:46:01 +01:00
|
|
|
|
2012-01-21 21:57:41 +01:00
|
|
|
safe_vector<string> pathlist;
|
|
|
|
list.GetPaths(pathlist, containing, path, m_wbfsFS);
|
2012-03-08 13:25:39 +01:00
|
|
|
list.GetHeaders(pathlist, *this, m_settingsDir, m_curLanguage, m_DMLgameDir);
|
2012-01-21 21:57:41 +01:00
|
|
|
|
|
|
|
path.append("/touch.db");
|
|
|
|
FILE *file = fopen(path.c_str(), "wb");
|
|
|
|
fclose(file);
|
|
|
|
remove(path.c_str());
|
|
|
|
|
2012-01-30 00:55:49 +01:00
|
|
|
m_loaded = true;
|
|
|
|
m_update = false;
|
2012-01-25 01:11:28 +01:00
|
|
|
|
2012-04-08 17:54:34 +02:00
|
|
|
if(!music && !update_emu && pathlist.size() > 0)
|
2012-01-21 21:57:41 +01:00
|
|
|
{
|
|
|
|
Save();
|
|
|
|
pathlist.clear();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
2012-02-03 04:00:13 +01:00
|
|
|
{
|
2012-01-21 21:57:41 +01:00
|
|
|
CCache<T>(*this, m_database, LOAD);
|
2012-01-30 00:55:49 +01:00
|
|
|
m_loaded = true;
|
|
|
|
}
|
2012-01-21 21:57:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
template<>
|
2012-02-03 04:00:13 +01:00
|
|
|
void CachedList<dir_discHdr>::LoadChannels(string path, u32 channelType, string m_lastLanguage) /* Load All */
|
2012-01-21 21:57:41 +01:00
|
|
|
{
|
|
|
|
m_loaded = false;
|
|
|
|
m_update = true;
|
|
|
|
|
|
|
|
bool emu = !path.empty();
|
|
|
|
if(emu)
|
|
|
|
{
|
|
|
|
m_database = sfmt("%s/%s.db", m_cacheDir.c_str(), make_db_name(sfmt("%s/emu", path.c_str())).c_str());
|
|
|
|
|
|
|
|
size_t find = m_database.find("//");
|
|
|
|
if(find != string::npos)
|
|
|
|
m_database.replace(find, 2, "/");
|
|
|
|
|
|
|
|
if(force_update[COVERFLOW_CHANNEL])
|
|
|
|
remove(m_database.c_str());
|
|
|
|
|
|
|
|
//gprintf("%s\n", m_database.c_str());
|
|
|
|
struct stat filestat, cache;
|
|
|
|
|
|
|
|
string newpath = sfmt("%s%s", path.c_str(), "title");
|
|
|
|
|
|
|
|
if(stat(newpath.c_str(), &filestat) == -1) return;
|
|
|
|
|
2012-02-03 04:00:13 +01:00
|
|
|
m_update = force_update[COVERFLOW_CHANNEL] || m_lastLanguage != m_curLanguage || stat(m_database.c_str(), &cache) == -1 || filestat.st_mtime > cache.st_mtime;
|
2012-01-21 21:57:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
force_update[COVERFLOW_CHANNEL] = false;
|
|
|
|
|
|
|
|
if(m_update)
|
|
|
|
{
|
2012-02-01 23:26:51 +01:00
|
|
|
gprintf("Updating channels\n");
|
2012-02-03 04:00:13 +01:00
|
|
|
list.GetChannels(*this, m_settingsDir, channelType, m_curLanguage);
|
2012-01-21 21:57:41 +01:00
|
|
|
|
|
|
|
m_loaded = true;
|
|
|
|
m_update = false;
|
|
|
|
|
|
|
|
if(this->size() > 0 && emu) Save();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
CCache<dir_discHdr>(*this, m_database, LOAD);
|
|
|
|
|
|
|
|
m_loaded = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
string CachedList<T>::make_db_name(string path)
|
|
|
|
{
|
|
|
|
string buffer = path;
|
|
|
|
size_t find = buffer.find(":/");
|
|
|
|
if(find != string::npos)
|
|
|
|
buffer.replace(find, 2, "_");
|
|
|
|
|
|
|
|
find = buffer.find("/");
|
|
|
|
while(find != string::npos)
|
|
|
|
{
|
|
|
|
buffer[find] = '_';
|
|
|
|
find = buffer.find("/");
|
|
|
|
}
|
|
|
|
return buffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
template class CachedList<string>;
|
|
|
|
template class CachedList<dir_discHdr>;
|