|
|
@ -3,9 +3,11 @@
|
|
|
|
|
|
|
|
|
|
|
|
#include <QDir>
|
|
|
|
#include <QDir>
|
|
|
|
#include <QTextCodec>
|
|
|
|
#include <QTextCodec>
|
|
|
|
#include <components/esm/esmreader.hpp>
|
|
|
|
#include <QMessageBox>
|
|
|
|
#include <QDebug>
|
|
|
|
#include <QDebug>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "components/esm/esmreader.hpp"
|
|
|
|
|
|
|
|
|
|
|
|
ContentSelectorModel::ContentModel::ContentModel(QObject *parent) :
|
|
|
|
ContentSelectorModel::ContentModel::ContentModel(QObject *parent) :
|
|
|
|
QAbstractTableModel(parent),
|
|
|
|
QAbstractTableModel(parent),
|
|
|
|
mMimeType ("application/omwcontent"),
|
|
|
|
mMimeType ("application/omwcontent"),
|
|
|
@ -380,15 +382,18 @@ bool ContentSelectorModel::ContentModel::canBeChecked(const EsmFile *file) const
|
|
|
|
//addon can be checked if its gamefile is
|
|
|
|
//addon can be checked if its gamefile is
|
|
|
|
foreach (const QString &fileName, file->gameFiles())
|
|
|
|
foreach (const QString &fileName, file->gameFiles())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
const EsmFile *dependency = item(fileName);
|
|
|
|
foreach (EsmFile *dependency, mFiles)
|
|
|
|
|
|
|
|
|
|
|
|
if (!dependency)
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (dependency->isGameFile())
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (isChecked(fileName))
|
|
|
|
//compare filenames only. Multiple instances
|
|
|
|
return true;
|
|
|
|
//of the filename (with different paths) is not relevant here.
|
|
|
|
|
|
|
|
if (!(dependency->fileName() == fileName))
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (dependency->isGameFile())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (isChecked(dependency->filePath()))
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
@ -396,7 +401,6 @@ bool ContentSelectorModel::ContentModel::canBeChecked(const EsmFile *file) const
|
|
|
|
|
|
|
|
|
|
|
|
void ContentSelectorModel::ContentModel::addFile(EsmFile *file)
|
|
|
|
void ContentSelectorModel::ContentModel::addFile(EsmFile *file)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
qDebug() << "adding file: " << file->filePath();
|
|
|
|
|
|
|
|
beginInsertRows(QModelIndex(), mFiles.count(), mFiles.count());
|
|
|
|
beginInsertRows(QModelIndex(), mFiles.count(), mFiles.count());
|
|
|
|
mFiles.append(file);
|
|
|
|
mFiles.append(file);
|
|
|
|
endInsertRows();
|
|
|
|
endInsertRows();
|
|
|
@ -418,8 +422,6 @@ void ContentSelectorModel::ContentModel::addFiles(const QString &path)
|
|
|
|
// Create a decoder for non-latin characters in esx metadata
|
|
|
|
// Create a decoder for non-latin characters in esx metadata
|
|
|
|
QTextDecoder *decoder = codec->makeDecoder();
|
|
|
|
QTextDecoder *decoder = codec->makeDecoder();
|
|
|
|
|
|
|
|
|
|
|
|
qDebug() << "searching path: " << path << " files found: " << dir.entryList().size();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (const QString &path, dir.entryList())
|
|
|
|
foreach (const QString &path, dir.entryList())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
QFileInfo info(dir.absoluteFilePath(path));
|
|
|
|
QFileInfo info(dir.absoluteFilePath(path));
|
|
|
@ -433,10 +435,7 @@ void ContentSelectorModel::ContentModel::addFiles(const QString &path)
|
|
|
|
fileReader.open(dir.absoluteFilePath(path).toStdString());
|
|
|
|
fileReader.open(dir.absoluteFilePath(path).toStdString());
|
|
|
|
|
|
|
|
|
|
|
|
foreach (const ESM::Header::MasterData &item, fileReader.getGameFiles())
|
|
|
|
foreach (const ESM::Header::MasterData &item, fileReader.getGameFiles())
|
|
|
|
{
|
|
|
|
|
|
|
|
qDebug() << "adding gamefile: " << item.name.c_str();
|
|
|
|
|
|
|
|
file->addGameFile(QString::fromStdString(item.name));
|
|
|
|
file->addGameFile(QString::fromStdString(item.name));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
file->setAuthor (decoder->toUnicode(fileReader.getAuthor().c_str()));
|
|
|
|
file->setAuthor (decoder->toUnicode(fileReader.getAuthor().c_str()));
|
|
|
|
file->setDate (info.lastModified());
|
|
|
|
file->setDate (info.lastModified());
|
|
|
@ -447,10 +446,7 @@ void ContentSelectorModel::ContentModel::addFiles(const QString &path)
|
|
|
|
|
|
|
|
|
|
|
|
// Put the file in the table
|
|
|
|
// Put the file in the table
|
|
|
|
if (item(file->filePath()) == 0)
|
|
|
|
if (item(file->filePath()) == 0)
|
|
|
|
{
|
|
|
|
|
|
|
|
qDebug () << "adding file " << file->filePath();
|
|
|
|
|
|
|
|
addFile(file);
|
|
|
|
addFile(file);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} catch(std::runtime_error &e) {
|
|
|
|
} catch(std::runtime_error &e) {
|
|
|
|
// An error occurred while reading the .esp
|
|
|
|
// An error occurred while reading the .esp
|
|
|
@ -510,10 +506,23 @@ bool ContentSelectorModel::ContentModel::isChecked(const QString& name) const
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ContentSelectorModel::ContentModel::setCheckState(const QString &name, bool checkState)
|
|
|
|
void ContentSelectorModel::ContentModel::setCheckStates (const QStringList &fileList, bool isChecked)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
foreach (const QString &file, fileList)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
setCheckState (file, isChecked);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool ContentSelectorModel::ContentModel::setCheckState(const QString &name, bool checkState)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (name.isEmpty())
|
|
|
|
if (name.isEmpty())
|
|
|
|
return;
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const EsmFile *file = item(name);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!file)
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
Qt::CheckState state = Qt::Unchecked;
|
|
|
|
Qt::CheckState state = Qt::Unchecked;
|
|
|
|
|
|
|
|
|
|
|
@ -523,8 +532,6 @@ void ContentSelectorModel::ContentModel::setCheckState(const QString &name, bool
|
|
|
|
mCheckStates[name] = state;
|
|
|
|
mCheckStates[name] = state;
|
|
|
|
emit dataChanged(indexFromItem(item(name)), indexFromItem(item(name)));
|
|
|
|
emit dataChanged(indexFromItem(item(name)), indexFromItem(item(name)));
|
|
|
|
|
|
|
|
|
|
|
|
const EsmFile *file = item(name);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (file->isGameFile())
|
|
|
|
if (file->isGameFile())
|
|
|
|
emit dataChanged (index(0,0), index(rowCount()-1,0));
|
|
|
|
emit dataChanged (index(0,0), index(rowCount()-1,0));
|
|
|
|
|
|
|
|
|
|
|
@ -559,29 +566,20 @@ void ContentSelectorModel::ContentModel::setCheckState(const QString &name, bool
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ContentSelectorModel::ContentFileList ContentSelectorModel::ContentModel::checkedItems() const
|
|
|
|
ContentSelectorModel::ContentFileList ContentSelectorModel::ContentModel::checkedItems() const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ContentFileList list;
|
|
|
|
ContentFileList list;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TODO:
|
|
|
|
// First search for game files and next addons,
|
|
|
|
// First search for game files and next addons,
|
|
|
|
// so we get more or less correct game files vs addons order.
|
|
|
|
// so we get more or less correct game files vs addons order.
|
|
|
|
foreach (EsmFile *file, mFiles)
|
|
|
|
foreach (EsmFile *file, mFiles)
|
|
|
|
{
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
|
|
|
|
if (isChecked(file->filePath()))
|
|
|
|
if (isChecked(file->filePath()))
|
|
|
|
=======
|
|
|
|
|
|
|
|
if (isChecked(file->fileName()) && file->isGameFile())
|
|
|
|
|
|
|
|
list << file;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (EsmFile *file, mFiles)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (isChecked(file->fileName()) && !file->isGameFile())
|
|
|
|
|
|
|
|
>>>>>>> f5fbe7361fad698e8dd3330e9820a157800be8ae
|
|
|
|
|
|
|
|
list << file;
|
|
|
|
list << file;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return list;
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
}
|
|
|
|