mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-16 16:10:58 +00:00
b88d32ff5b
1 with the data directories 2 with the BSA archives 3 with the content selector When user select a directory to be added, first we walk the directory hierarchy to make a list of all potential data= entries. If we find none, the selected directory is added. If more than one data directory is found, user is presented with a directory list to check which one(s) are to be added. Directories containing one or more content file are marked with an icon. data= and fallback-archive= lines are handled like content= lines: - they are part of the profile in launcher.cfg, prefixed by the profile name - they are updated in openmw.cfg when profile is selected / created Directories can be moved in the list by drag and drop or by buttons. Insertion is possible anywhere in the list. Global data path and data local are shown but are greyed out, as they are always included. No attempt is made to ensure that the user choice are valid (dependencies, overwrite of content). After a profile is loaded, any added content is highlighted in green.
68 lines
2.5 KiB
C++
68 lines
2.5 KiB
C++
#ifndef LAUNCHERSETTINGS_HPP
|
|
#define LAUNCHERSETTINGS_HPP
|
|
|
|
#include "settingsbase.hpp"
|
|
#include "gamesettings.hpp"
|
|
|
|
namespace Config
|
|
{
|
|
class LauncherSettings : public SettingsBase<QMultiMap<QString, QString> >
|
|
{
|
|
public:
|
|
bool writeFile(QTextStream &stream);
|
|
|
|
/// \return names of all Content Lists in the launcher's .cfg file.
|
|
QStringList getContentLists();
|
|
|
|
/// Set initially selected content list to match values from openmw.cfg, creating if necessary
|
|
void setContentList(const GameSettings& gameSettings);
|
|
|
|
/// Create a Content List (or replace if it already exists)
|
|
void setContentList(const QString& contentListName, const QStringList& dirNames, const QStringList& archiveNames, const QStringList& fileNames);
|
|
|
|
void removeContentList(const QString &contentListName);
|
|
|
|
void setCurrentContentListName(const QString &contentListName);
|
|
|
|
QString getCurrentContentListName() const;
|
|
|
|
QStringList getDataDirectoryList(const QString& contentListName) const;
|
|
QStringList getArchiveList(const QString& contentListName) const;
|
|
QStringList getContentListFiles(const QString& contentListName) const;
|
|
|
|
/// \return new list that is reversed order of input
|
|
static QStringList reverse(const QStringList& toReverse);
|
|
|
|
static const char sLauncherConfigFileName[];
|
|
|
|
private:
|
|
|
|
/// \return key to use to get/set the files in the specified data Directory List
|
|
static QString makeDirectoryListKey(const QString& contentListName);
|
|
|
|
/// \return key to use to get/set the files in the specified Archive List
|
|
static QString makeArchiveListKey(const QString& contentListName);
|
|
|
|
/// \return key to use to get/set the files in the specified Content List
|
|
static QString makeContentListKey(const QString& contentListName);
|
|
|
|
/// \return true if both lists are same
|
|
static bool isEqual(const QStringList& list1, const QStringList& list2);
|
|
|
|
static QString makeNewContentListName();
|
|
|
|
QStringList subKeys(const QString &key);
|
|
|
|
/// name of entry in launcher.cfg that holds name of currently selected Content List
|
|
static const char sCurrentContentListKey[];
|
|
|
|
/// section of launcher.cfg holding the Content Lists
|
|
static const char sContentListsSectionPrefix[];
|
|
|
|
static const char sDirectoryListSuffix[];
|
|
static const char sArchiveListSuffix[];
|
|
static const char sContentListSuffix[];
|
|
};
|
|
}
|
|
#endif // LAUNCHERSETTINGS_HPP
|