|
|
|
|
@@ -47,24 +47,24 @@
|
|
|
|
|
|
|
|
|
|
#define MAX_SIZE 1024
|
|
|
|
|
|
|
|
|
|
IconList::IconList(const QStringList& builtinPaths, QString path, QObject* parent) : QAbstractListModel(parent)
|
|
|
|
|
IconList::IconList(const QStringList& builtinPaths, const QString& path, QObject* parent) : QAbstractListModel(parent)
|
|
|
|
|
{
|
|
|
|
|
QSet<QString> builtinNames;
|
|
|
|
|
|
|
|
|
|
// add builtin icons
|
|
|
|
|
for (auto& builtinPath : builtinPaths) {
|
|
|
|
|
QDir instance_icons(builtinPath);
|
|
|
|
|
auto file_info_list = instance_icons.entryInfoList(QDir::Files, QDir::Name);
|
|
|
|
|
for (auto file_info : file_info_list) {
|
|
|
|
|
builtinNames.insert(file_info.completeBaseName());
|
|
|
|
|
for (const auto& builtinPath : builtinPaths) {
|
|
|
|
|
QDir instanceIcons(builtinPath);
|
|
|
|
|
auto fileInfoList = instanceIcons.entryInfoList(QDir::Files, QDir::Name);
|
|
|
|
|
for (const auto& fileInfo : fileInfoList) {
|
|
|
|
|
builtinNames.insert(fileInfo.baseName());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
for (auto& builtinName : builtinNames) {
|
|
|
|
|
for (const auto& builtinName : builtinNames) {
|
|
|
|
|
addThemeIcon(builtinName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
m_watcher.reset(new QFileSystemWatcher());
|
|
|
|
|
is_watching = false;
|
|
|
|
|
m_isWatching = false;
|
|
|
|
|
connect(m_watcher.get(), &QFileSystemWatcher::directoryChanged, this, &IconList::directoryChanged);
|
|
|
|
|
connect(m_watcher.get(), &QFileSystemWatcher::fileChanged, this, &IconList::fileChanged);
|
|
|
|
|
|
|
|
|
|
@@ -77,91 +77,130 @@ IconList::IconList(const QStringList& builtinPaths, QString path, QObject* paren
|
|
|
|
|
void IconList::sortIconList()
|
|
|
|
|
{
|
|
|
|
|
qDebug() << "Sorting icon list...";
|
|
|
|
|
std::sort(icons.begin(), icons.end(), [](const MMCIcon& a, const MMCIcon& b) { return a.m_key.localeAwareCompare(b.m_key) < 0; });
|
|
|
|
|
std::sort(m_icons.begin(), m_icons.end(), [](const MMCIcon& a, const MMCIcon& b) {
|
|
|
|
|
bool aIsSubdir = a.m_key.contains(QDir::separator());
|
|
|
|
|
bool bIsSubdir = b.m_key.contains(QDir::separator());
|
|
|
|
|
if (aIsSubdir != bIsSubdir) {
|
|
|
|
|
return !aIsSubdir; // root-level icons come first
|
|
|
|
|
}
|
|
|
|
|
return a.m_key.localeAwareCompare(b.m_key) < 0;
|
|
|
|
|
});
|
|
|
|
|
reindex();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Helper function to add directories recursively
|
|
|
|
|
bool IconList::addPathRecursively(const QString& path)
|
|
|
|
|
{
|
|
|
|
|
QDir dir(path);
|
|
|
|
|
if (!dir.exists())
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
// Add the directory itself
|
|
|
|
|
bool watching = m_watcher->addPath(path);
|
|
|
|
|
|
|
|
|
|
// Add all subdirectories
|
|
|
|
|
QFileInfoList entries = dir.entryInfoList(QDir::Dirs | QDir::NoDotAndDotDot);
|
|
|
|
|
for (const QFileInfo& entry : entries) {
|
|
|
|
|
if (addPathRecursively(entry.absoluteFilePath())) {
|
|
|
|
|
watching = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return watching;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QStringList IconList::getIconFilePaths() const
|
|
|
|
|
{
|
|
|
|
|
QStringList iconFiles{};
|
|
|
|
|
QStringList directories{ m_dir.absolutePath() };
|
|
|
|
|
while (!directories.isEmpty()) {
|
|
|
|
|
QString first = directories.takeFirst();
|
|
|
|
|
QDir dir(first);
|
|
|
|
|
for (QFileInfo& fileInfo : dir.entryInfoList(QDir::AllDirs | QDir::Files | QDir::NoDotAndDotDot, QDir::Name)) {
|
|
|
|
|
if (fileInfo.isDir())
|
|
|
|
|
directories.push_back(fileInfo.absoluteFilePath());
|
|
|
|
|
else
|
|
|
|
|
iconFiles.push_back(fileInfo.absoluteFilePath());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return iconFiles;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString formatName(const QDir& iconsDir, const QFileInfo& iconFile)
|
|
|
|
|
{
|
|
|
|
|
if (iconFile.dir() == iconsDir)
|
|
|
|
|
return iconFile.baseName();
|
|
|
|
|
|
|
|
|
|
constexpr auto delimiter = " » ";
|
|
|
|
|
QString relativePathWithoutExtension = iconsDir.relativeFilePath(iconFile.dir().path()) + QDir::separator() + iconFile.baseName();
|
|
|
|
|
return relativePathWithoutExtension.replace(QDir::separator(), delimiter);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Split into a separate function because the preprocessing impedes readability
|
|
|
|
|
QSet<QString> toStringSet(const QList<QString>& list)
|
|
|
|
|
{
|
|
|
|
|
#if QT_VERSION >= QT_VERSION_CHECK(5, 14, 0)
|
|
|
|
|
QSet<QString> set(list.begin(), list.end());
|
|
|
|
|
#else
|
|
|
|
|
QSet<QString> set = list.toSet();
|
|
|
|
|
#endif
|
|
|
|
|
return set;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void IconList::directoryChanged(const QString& path)
|
|
|
|
|
{
|
|
|
|
|
QDir new_dir(path);
|
|
|
|
|
if (m_dir.absolutePath() != new_dir.absolutePath()) {
|
|
|
|
|
m_dir.setPath(path);
|
|
|
|
|
QDir newDir(path);
|
|
|
|
|
if (m_dir.absolutePath() != newDir.absolutePath()) {
|
|
|
|
|
if (!path.startsWith(m_dir.absolutePath()))
|
|
|
|
|
m_dir.setPath(path);
|
|
|
|
|
m_dir.refresh();
|
|
|
|
|
if (is_watching)
|
|
|
|
|
if (m_isWatching)
|
|
|
|
|
stopWatching();
|
|
|
|
|
startWatching();
|
|
|
|
|
}
|
|
|
|
|
if (!m_dir.exists())
|
|
|
|
|
if (!FS::ensureFolderPathExists(m_dir.absolutePath()))
|
|
|
|
|
return;
|
|
|
|
|
if (!m_dir.exists() && !FS::ensureFolderPathExists(m_dir.absolutePath()))
|
|
|
|
|
return;
|
|
|
|
|
m_dir.refresh();
|
|
|
|
|
auto new_list = m_dir.entryList(QDir::Files, QDir::Name);
|
|
|
|
|
for (auto it = new_list.begin(); it != new_list.end(); it++) {
|
|
|
|
|
QString& foo = (*it);
|
|
|
|
|
foo = m_dir.filePath(foo);
|
|
|
|
|
}
|
|
|
|
|
#if QT_VERSION >= QT_VERSION_CHECK(5, 14, 0)
|
|
|
|
|
QSet<QString> new_set(new_list.begin(), new_list.end());
|
|
|
|
|
#else
|
|
|
|
|
auto new_set = new_list.toSet();
|
|
|
|
|
#endif
|
|
|
|
|
QList<QString> current_list;
|
|
|
|
|
for (auto& it : icons) {
|
|
|
|
|
const QStringList newFileNamesList = getIconFilePaths();
|
|
|
|
|
const QSet<QString> newSet = toStringSet(newFileNamesList);
|
|
|
|
|
QSet<QString> currentSet;
|
|
|
|
|
for (const MMCIcon& it : m_icons) {
|
|
|
|
|
if (!it.has(IconType::FileBased))
|
|
|
|
|
continue;
|
|
|
|
|
current_list.push_back(it.m_images[IconType::FileBased].filename);
|
|
|
|
|
currentSet.insert(it.m_images[IconType::FileBased].filename);
|
|
|
|
|
}
|
|
|
|
|
#if QT_VERSION >= QT_VERSION_CHECK(5, 14, 0)
|
|
|
|
|
QSet<QString> current_set(current_list.begin(), current_list.end());
|
|
|
|
|
#else
|
|
|
|
|
QSet<QString> current_set = current_list.toSet();
|
|
|
|
|
#endif
|
|
|
|
|
QSet<QString> toRemove = currentSet - newSet;
|
|
|
|
|
QSet<QString> toAdd = newSet - currentSet;
|
|
|
|
|
|
|
|
|
|
QSet<QString> to_remove = current_set;
|
|
|
|
|
to_remove -= new_set;
|
|
|
|
|
|
|
|
|
|
QSet<QString> to_add = new_set;
|
|
|
|
|
to_add -= current_set;
|
|
|
|
|
|
|
|
|
|
for (auto remove : to_remove) {
|
|
|
|
|
qDebug() << "Removing " << remove;
|
|
|
|
|
QFileInfo rmfile(remove);
|
|
|
|
|
QString key = rmfile.completeBaseName();
|
|
|
|
|
|
|
|
|
|
QString suffix = rmfile.suffix();
|
|
|
|
|
// The icon doesnt have a suffix, but it can have other .s in the name, so we account for those as well
|
|
|
|
|
if (!IconUtils::isIconSuffix(suffix))
|
|
|
|
|
key = rmfile.fileName();
|
|
|
|
|
for (const QString& removedPath : toRemove) {
|
|
|
|
|
qDebug() << "Removing icon " << removedPath;
|
|
|
|
|
QFileInfo removedFile(removedPath);
|
|
|
|
|
QString key = m_dir.relativeFilePath(removedFile.absoluteFilePath());
|
|
|
|
|
|
|
|
|
|
int idx = getIconIndex(key);
|
|
|
|
|
if (idx == -1)
|
|
|
|
|
continue;
|
|
|
|
|
icons[idx].remove(IconType::FileBased);
|
|
|
|
|
if (icons[idx].type() == IconType::ToBeDeleted) {
|
|
|
|
|
m_icons[idx].remove(FileBased);
|
|
|
|
|
if (m_icons[idx].type() == ToBeDeleted) {
|
|
|
|
|
beginRemoveRows(QModelIndex(), idx, idx);
|
|
|
|
|
icons.remove(idx);
|
|
|
|
|
m_icons.remove(idx);
|
|
|
|
|
reindex();
|
|
|
|
|
endRemoveRows();
|
|
|
|
|
} else {
|
|
|
|
|
dataChanged(index(idx), index(idx));
|
|
|
|
|
}
|
|
|
|
|
m_watcher->removePath(remove);
|
|
|
|
|
m_watcher->removePath(removedPath);
|
|
|
|
|
emit iconUpdated(key);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (auto add : to_add) {
|
|
|
|
|
qDebug() << "Adding " << add;
|
|
|
|
|
for (const QString& addedPath : toAdd) {
|
|
|
|
|
qDebug() << "Adding icon " << addedPath;
|
|
|
|
|
|
|
|
|
|
QFileInfo addfile(add);
|
|
|
|
|
QString key = addfile.completeBaseName();
|
|
|
|
|
QFileInfo addfile(addedPath);
|
|
|
|
|
QString key = m_dir.relativeFilePath(addfile.absoluteFilePath());
|
|
|
|
|
QString name = formatName(m_dir, addfile);
|
|
|
|
|
|
|
|
|
|
QString suffix = addfile.suffix();
|
|
|
|
|
// The icon doesnt have a suffix, but it can have other .s in the name, so we account for those as well
|
|
|
|
|
if (!IconUtils::isIconSuffix(suffix))
|
|
|
|
|
key = addfile.fileName();
|
|
|
|
|
|
|
|
|
|
if (addIcon(key, QString(), addfile.filePath(), IconType::FileBased)) {
|
|
|
|
|
m_watcher->addPath(add);
|
|
|
|
|
if (addIcon(key, name, addfile.filePath(), IconType::FileBased)) {
|
|
|
|
|
m_watcher->addPath(addedPath);
|
|
|
|
|
emit iconUpdated(key);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
@@ -171,24 +210,24 @@ void IconList::directoryChanged(const QString& path)
|
|
|
|
|
|
|
|
|
|
void IconList::fileChanged(const QString& path)
|
|
|
|
|
{
|
|
|
|
|
qDebug() << "Checking " << path;
|
|
|
|
|
qDebug() << "Checking icon " << path;
|
|
|
|
|
QFileInfo checkfile(path);
|
|
|
|
|
if (!checkfile.exists())
|
|
|
|
|
return;
|
|
|
|
|
QString key = checkfile.completeBaseName();
|
|
|
|
|
QString key = m_dir.relativeFilePath(checkfile.absoluteFilePath());
|
|
|
|
|
int idx = getIconIndex(key);
|
|
|
|
|
if (idx == -1)
|
|
|
|
|
return;
|
|
|
|
|
QIcon icon(path);
|
|
|
|
|
if (!icon.availableSizes().size())
|
|
|
|
|
if (icon.availableSizes().empty())
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
icons[idx].m_images[IconType::FileBased].icon = icon;
|
|
|
|
|
m_icons[idx].m_images[IconType::FileBased].icon = icon;
|
|
|
|
|
dataChanged(index(idx), index(idx));
|
|
|
|
|
emit iconUpdated(key);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void IconList::SettingChanged(const Setting& setting, QVariant value)
|
|
|
|
|
void IconList::SettingChanged(const Setting& setting, const QVariant& value)
|
|
|
|
|
{
|
|
|
|
|
if (setting.id() != "IconsDir")
|
|
|
|
|
return;
|
|
|
|
|
@@ -200,8 +239,8 @@ void IconList::startWatching()
|
|
|
|
|
{
|
|
|
|
|
auto abs_path = m_dir.absolutePath();
|
|
|
|
|
FS::ensureFolderPathExists(abs_path);
|
|
|
|
|
is_watching = m_watcher->addPath(abs_path);
|
|
|
|
|
if (is_watching) {
|
|
|
|
|
m_isWatching = addPathRecursively(abs_path);
|
|
|
|
|
if (m_isWatching) {
|
|
|
|
|
qDebug() << "Started watching " << abs_path;
|
|
|
|
|
} else {
|
|
|
|
|
qDebug() << "Failed to start watching " << abs_path;
|
|
|
|
|
@@ -212,7 +251,7 @@ void IconList::stopWatching()
|
|
|
|
|
{
|
|
|
|
|
m_watcher->removePaths(m_watcher->files());
|
|
|
|
|
m_watcher->removePaths(m_watcher->directories());
|
|
|
|
|
is_watching = false;
|
|
|
|
|
m_isWatching = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QStringList IconList::mimeTypes() const
|
|
|
|
|
@@ -242,7 +281,7 @@ bool IconList::dropMimeData(const QMimeData* data,
|
|
|
|
|
if (data->hasUrls()) {
|
|
|
|
|
auto urls = data->urls();
|
|
|
|
|
QStringList iconFiles;
|
|
|
|
|
for (auto url : urls) {
|
|
|
|
|
for (const auto& url : urls) {
|
|
|
|
|
// only local files may be dropped...
|
|
|
|
|
if (!url.isLocalFile())
|
|
|
|
|
continue;
|
|
|
|
|
@@ -263,33 +302,33 @@ Qt::ItemFlags IconList::flags(const QModelIndex& index) const
|
|
|
|
|
QVariant IconList::data(const QModelIndex& index, int role) const
|
|
|
|
|
{
|
|
|
|
|
if (!index.isValid())
|
|
|
|
|
return QVariant();
|
|
|
|
|
return {};
|
|
|
|
|
|
|
|
|
|
int row = index.row();
|
|
|
|
|
|
|
|
|
|
if (row < 0 || row >= icons.size())
|
|
|
|
|
return QVariant();
|
|
|
|
|
if (row < 0 || row >= m_icons.size())
|
|
|
|
|
return {};
|
|
|
|
|
|
|
|
|
|
switch (role) {
|
|
|
|
|
case Qt::DecorationRole:
|
|
|
|
|
return icons[row].icon();
|
|
|
|
|
return m_icons[row].icon();
|
|
|
|
|
case Qt::DisplayRole:
|
|
|
|
|
return icons[row].name();
|
|
|
|
|
return m_icons[row].name();
|
|
|
|
|
case Qt::UserRole:
|
|
|
|
|
return icons[row].m_key;
|
|
|
|
|
return m_icons[row].m_key;
|
|
|
|
|
default:
|
|
|
|
|
return QVariant();
|
|
|
|
|
return {};
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int IconList::rowCount(const QModelIndex& parent) const
|
|
|
|
|
{
|
|
|
|
|
return parent.isValid() ? 0 : icons.size();
|
|
|
|
|
return parent.isValid() ? 0 : m_icons.size();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void IconList::installIcons(const QStringList& iconFiles)
|
|
|
|
|
{
|
|
|
|
|
for (QString file : iconFiles)
|
|
|
|
|
for (const QString& file : iconFiles)
|
|
|
|
|
installIcon(file, {});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@@ -312,12 +351,13 @@ bool IconList::iconFileExists(const QString& key) const
|
|
|
|
|
return iconEntry && iconEntry->has(IconType::FileBased);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Returns the icon with the given key or nullptr if it doesn't exist.
|
|
|
|
|
const MMCIcon* IconList::icon(const QString& key) const
|
|
|
|
|
{
|
|
|
|
|
int iconIdx = getIconIndex(key);
|
|
|
|
|
if (iconIdx == -1)
|
|
|
|
|
return nullptr;
|
|
|
|
|
return &icons[iconIdx];
|
|
|
|
|
return &m_icons[iconIdx];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool IconList::deleteIcon(const QString& key)
|
|
|
|
|
@@ -332,22 +372,22 @@ bool IconList::trashIcon(const QString& key)
|
|
|
|
|
|
|
|
|
|
bool IconList::addThemeIcon(const QString& key)
|
|
|
|
|
{
|
|
|
|
|
auto iter = name_index.find(key);
|
|
|
|
|
if (iter != name_index.end()) {
|
|
|
|
|
auto& oldOne = icons[*iter];
|
|
|
|
|
auto iter = m_nameIndex.find(key);
|
|
|
|
|
if (iter != m_nameIndex.end()) {
|
|
|
|
|
auto& oldOne = m_icons[*iter];
|
|
|
|
|
oldOne.replace(Builtin, key);
|
|
|
|
|
dataChanged(index(*iter), index(*iter));
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
// add a new icon
|
|
|
|
|
beginInsertRows(QModelIndex(), icons.size(), icons.size());
|
|
|
|
|
beginInsertRows(QModelIndex(), m_icons.size(), m_icons.size());
|
|
|
|
|
{
|
|
|
|
|
MMCIcon mmc_icon;
|
|
|
|
|
mmc_icon.m_name = key;
|
|
|
|
|
mmc_icon.m_key = key;
|
|
|
|
|
mmc_icon.replace(Builtin, key);
|
|
|
|
|
icons.push_back(mmc_icon);
|
|
|
|
|
name_index[key] = icons.size() - 1;
|
|
|
|
|
m_icons.push_back(mmc_icon);
|
|
|
|
|
m_nameIndex[key] = m_icons.size() - 1;
|
|
|
|
|
}
|
|
|
|
|
endInsertRows();
|
|
|
|
|
return true;
|
|
|
|
|
@@ -359,22 +399,22 @@ bool IconList::addIcon(const QString& key, const QString& name, const QString& p
|
|
|
|
|
QIcon icon(path);
|
|
|
|
|
if (icon.isNull())
|
|
|
|
|
return false;
|
|
|
|
|
auto iter = name_index.find(key);
|
|
|
|
|
if (iter != name_index.end()) {
|
|
|
|
|
auto& oldOne = icons[*iter];
|
|
|
|
|
auto iter = m_nameIndex.find(key);
|
|
|
|
|
if (iter != m_nameIndex.end()) {
|
|
|
|
|
auto& oldOne = m_icons[*iter];
|
|
|
|
|
oldOne.replace(type, icon, path);
|
|
|
|
|
dataChanged(index(*iter), index(*iter));
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
// add a new icon
|
|
|
|
|
beginInsertRows(QModelIndex(), icons.size(), icons.size());
|
|
|
|
|
beginInsertRows(QModelIndex(), m_icons.size(), m_icons.size());
|
|
|
|
|
{
|
|
|
|
|
MMCIcon mmc_icon;
|
|
|
|
|
mmc_icon.m_name = name;
|
|
|
|
|
mmc_icon.m_key = key;
|
|
|
|
|
mmc_icon.replace(type, icon, path);
|
|
|
|
|
icons.push_back(mmc_icon);
|
|
|
|
|
name_index[key] = icons.size() - 1;
|
|
|
|
|
m_icons.push_back(mmc_icon);
|
|
|
|
|
m_nameIndex[key] = m_icons.size() - 1;
|
|
|
|
|
}
|
|
|
|
|
endInsertRows();
|
|
|
|
|
return true;
|
|
|
|
|
@@ -389,33 +429,32 @@ void IconList::saveIcon(const QString& key, const QString& path, const char* for
|
|
|
|
|
|
|
|
|
|
void IconList::reindex()
|
|
|
|
|
{
|
|
|
|
|
name_index.clear();
|
|
|
|
|
int i = 0;
|
|
|
|
|
for (auto& iter : icons) {
|
|
|
|
|
name_index[iter.m_key] = i;
|
|
|
|
|
i++;
|
|
|
|
|
m_nameIndex.clear();
|
|
|
|
|
for (int i = 0; i < m_icons.size(); i++) {
|
|
|
|
|
m_nameIndex[m_icons[i].m_key] = i;
|
|
|
|
|
emit iconUpdated(m_icons[i].m_key); // prevents incorrect indices with proxy model
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QIcon IconList::getIcon(const QString& key) const
|
|
|
|
|
{
|
|
|
|
|
int icon_index = getIconIndex(key);
|
|
|
|
|
int iconIndex = getIconIndex(key);
|
|
|
|
|
|
|
|
|
|
if (icon_index != -1)
|
|
|
|
|
return icons[icon_index].icon();
|
|
|
|
|
if (iconIndex != -1)
|
|
|
|
|
return m_icons[iconIndex].icon();
|
|
|
|
|
|
|
|
|
|
// Fallback for icons that don't exist.
|
|
|
|
|
icon_index = getIconIndex("grass");
|
|
|
|
|
// Fallback for icons that don't exist.b
|
|
|
|
|
iconIndex = getIconIndex("grass");
|
|
|
|
|
|
|
|
|
|
if (icon_index != -1)
|
|
|
|
|
return icons[icon_index].icon();
|
|
|
|
|
return QIcon();
|
|
|
|
|
if (iconIndex != -1)
|
|
|
|
|
return m_icons[iconIndex].icon();
|
|
|
|
|
return {};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int IconList::getIconIndex(const QString& key) const
|
|
|
|
|
{
|
|
|
|
|
auto iter = name_index.find(key == "default" ? "grass" : key);
|
|
|
|
|
if (iter != name_index.end())
|
|
|
|
|
auto iter = m_nameIndex.find(key == "default" ? "grass" : key);
|
|
|
|
|
if (iter != m_nameIndex.end())
|
|
|
|
|
return *iter;
|
|
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
|
@@ -425,3 +464,15 @@ QString IconList::getDirectory() const
|
|
|
|
|
{
|
|
|
|
|
return m_dir.absolutePath();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Returns the directory of the icon with the given key or the default directory if it's a builtin icon.
|
|
|
|
|
QString IconList::iconDirectory(const QString& key) const
|
|
|
|
|
{
|
|
|
|
|
for (const auto& mmcIcon : m_icons) {
|
|
|
|
|
if (mmcIcon.m_key == key && mmcIcon.has(IconType::FileBased)) {
|
|
|
|
|
QFileInfo iconFile(mmcIcon.getFilePath());
|
|
|
|
|
return iconFile.dir().path();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return getDirectory();
|
|
|
|
|
}
|
|
|
|
|
|