@ -7,6 +7,11 @@
# include <QDebug>
# include <QDebug>
const char Config : : LauncherSettings : : sCurrentContentListKey [ ] = " Profiles/currentprofile " ;
const char Config : : LauncherSettings : : sLauncherConfigFileName [ ] = " launcher.cfg " ;
const char Config : : LauncherSettings : : sContentListsSectionPrefix [ ] = " Profiles/ " ;
const char Config : : LauncherSettings : : sContentListSuffix [ ] = " /content " ;
Config : : LauncherSettings : : LauncherSettings ( )
Config : : LauncherSettings : : LauncherSettings ( )
{
{
}
}
@ -15,27 +20,6 @@ Config::LauncherSettings::~LauncherSettings()
{
{
}
}
QStringList Config : : LauncherSettings : : values ( const QString & key , Qt : : MatchFlags flags )
{
QMap < QString , QString > settings = SettingsBase : : getSettings ( ) ;
if ( flags = = Qt : : MatchExactly )
return settings . values ( key ) ;
QStringList result ;
if ( flags = = Qt : : MatchStartsWith ) {
QStringList keys = settings . keys ( ) ;
foreach ( const QString & currentKey , keys ) {
if ( currentKey . startsWith ( key ) )
result . append ( settings . value ( currentKey ) ) ;
}
}
return result ;
}
QStringList Config : : LauncherSettings : : subKeys ( const QString & key )
QStringList Config : : LauncherSettings : : subKeys ( const QString & key )
{
{
QMap < QString , QString > settings = SettingsBase : : getSettings ( ) ;
QMap < QString , QString > settings = SettingsBase : : getSettings ( ) ;
@ -66,6 +50,7 @@ QStringList Config::LauncherSettings::subKeys(const QString &key)
return result ;
return result ;
}
}
bool Config : : LauncherSettings : : writeFile ( QTextStream & stream )
bool Config : : LauncherSettings : : writeFile ( QTextStream & stream )
{
{
QString sectionPrefix ;
QString sectionPrefix ;
@ -104,3 +89,110 @@ bool Config::LauncherSettings::writeFile(QTextStream &stream)
return true ;
return true ;
}
}
QStringList Config : : LauncherSettings : : getContentLists ( )
{
return subKeys ( QString ( sContentListsSectionPrefix ) ) ;
}
QString Config : : LauncherSettings : : makeContentListKey ( const QString & contentListName )
{
return QString ( sContentListsSectionPrefix ) + contentListName + QString ( sContentListSuffix ) ;
}
void Config : : LauncherSettings : : setContentList ( const GameSettings & gameSettings )
{
// obtain content list from game settings (if present)
const QStringList files ( gameSettings . getContentList ( ) ) ;
// if any existing profile in launcher matches the content list, make that profile the default
foreach ( const QString & listName , getContentLists ( ) )
{
if ( isEqual ( files , getContentListFiles ( listName ) ) )
{
setCurrentContentListName ( listName ) ;
return ;
}
}
// otherwise, add content list
QString newContentListName ( makeNewContentListName ( ) ) ;
setCurrentContentListName ( newContentListName ) ;
setContentList ( newContentListName , files ) ;
}
void Config : : LauncherSettings : : removeContentList ( const QString & contentListName )
{
remove ( makeContentListKey ( contentListName ) ) ;
}
void Config : : LauncherSettings : : setCurrentContentListName ( const QString & contentListName )
{
remove ( QString ( sCurrentContentListKey ) ) ;
setValue ( QString ( sCurrentContentListKey ) , contentListName ) ;
}
void Config : : LauncherSettings : : setContentList ( const QString & contentListName , const QStringList & fileNames )
{
removeContentList ( contentListName ) ;
QString key = makeContentListKey ( contentListName ) ;
foreach ( const QString & fileName , fileNames )
{
setMultiValue ( key , fileName ) ;
}
}
QString Config : : LauncherSettings : : getCurrentContentListName ( ) const
{
return value ( QString ( sCurrentContentListKey ) ) ;
}
QStringList Config : : LauncherSettings : : getContentListFiles ( const QString & contentListName ) const
{
// QMap returns multiple rows in LIFO order, so need to reverse
return reverse ( getSettings ( ) . values ( makeContentListKey ( contentListName ) ) ) ;
}
QStringList Config : : LauncherSettings : : reverse ( const QStringList & toReverse )
{
QStringList result ;
result . reserve ( toReverse . size ( ) ) ;
std : : reverse_copy ( toReverse . begin ( ) , toReverse . end ( ) , std : : back_inserter ( result ) ) ;
return result ;
}
bool Config : : LauncherSettings : : isEqual ( const QStringList & list1 , const QStringList & list2 )
{
if ( list1 . count ( ) ! = list2 . count ( ) )
{
return false ;
}
for ( int i = 0 ; i < list1 . count ( ) ; + + i )
{
if ( list1 . at ( i ) ! = list2 . at ( i ) )
{
return false ;
}
}
// if get here, lists are same
return true ;
}
QString Config : : LauncherSettings : : makeNewContentListName ( )
{
// basically, use date and time as the name e.g. YYYY-MM-DDThh:mm:ss
time_t rawtime ;
struct tm * timeinfo ;
time ( & rawtime ) ;
timeinfo = localtime ( & rawtime ) ;
int base = 10 ;
QChar zeroPad ( ' 0 ' ) ;
return QString ( " %1-%2-%3T%4:%5:%6 " )
. arg ( timeinfo - > tm_year + 1900 , 4 ) . arg ( timeinfo - > tm_mon + 1 , 2 , base , zeroPad ) . arg ( timeinfo - > tm_mday , 2 , base , zeroPad )
. arg ( timeinfo - > tm_hour , 2 , base , zeroPad ) . arg ( timeinfo - > tm_min , 2 , base , zeroPad ) . arg ( timeinfo - > tm_sec , 2 , base , zeroPad ) ;
}