7705f290ca
Avoids an infinite loop when the image is too big. Signed-off-by: flow <flowlnlnln@gmail.com>
123 lines
3.6 KiB
C++
123 lines
3.6 KiB
C++
#include "ResourcePack.h"
|
|
|
|
#include <QDebug>
|
|
#include <QMap>
|
|
#include <QRegularExpression>
|
|
|
|
#include "Version.h"
|
|
|
|
#include "minecraft/mod/tasks/LocalResourcePackParseTask.h"
|
|
|
|
// Values taken from:
|
|
// https://minecraft.fandom.com/wiki/Tutorials/Creating_a_resource_pack#Formatting_pack.mcmeta
|
|
static const QMap<int, std::pair<Version, Version>> s_pack_format_versions = {
|
|
{ 1, { Version("1.6.1"), Version("1.8.9") } }, { 2, { Version("1.9"), Version("1.10.2") } },
|
|
{ 3, { Version("1.11"), Version("1.12.2") } }, { 4, { Version("1.13"), Version("1.14.4") } },
|
|
{ 5, { Version("1.15"), Version("1.16.1") } }, { 6, { Version("1.16.2"), Version("1.16.5") } },
|
|
{ 7, { Version("1.17"), Version("1.17.1") } }, { 8, { Version("1.18"), Version("1.18.2") } },
|
|
{ 9, { Version("1.19"), Version("1.19.2") } },
|
|
};
|
|
|
|
void ResourcePack::setPackFormat(int new_format_id)
|
|
{
|
|
QMutexLocker locker(&m_data_lock);
|
|
|
|
if (!s_pack_format_versions.contains(new_format_id)) {
|
|
qWarning() << "Pack format '%1' is not a recognized resource pack id!";
|
|
}
|
|
|
|
m_pack_format = new_format_id;
|
|
}
|
|
|
|
void ResourcePack::setDescription(QString new_description)
|
|
{
|
|
QMutexLocker locker(&m_data_lock);
|
|
|
|
m_description = new_description;
|
|
}
|
|
|
|
void ResourcePack::setImage(QImage new_image)
|
|
{
|
|
QMutexLocker locker(&m_data_lock);
|
|
|
|
Q_ASSERT(!new_image.isNull());
|
|
|
|
if (m_pack_image_cache_key.key.isValid())
|
|
QPixmapCache::remove(m_pack_image_cache_key.key);
|
|
|
|
m_pack_image_cache_key.key = QPixmapCache::insert(QPixmap::fromImage(new_image));
|
|
m_pack_image_cache_key.was_ever_used = true;
|
|
|
|
// This can happen if the pixmap is too big to fit in the cache :c
|
|
if (!m_pack_image_cache_key.key.isValid()) {
|
|
qWarning() << "Could not insert a image cache entry! Ignoring it.";
|
|
m_pack_image_cache_key.was_ever_used = false;
|
|
}
|
|
}
|
|
|
|
QPixmap ResourcePack::image(QSize size)
|
|
{
|
|
QPixmap cached_image;
|
|
if (QPixmapCache::find(m_pack_image_cache_key.key, &cached_image)) {
|
|
if (size.isNull())
|
|
return cached_image;
|
|
return cached_image.scaled(size);
|
|
}
|
|
|
|
// No valid image we can get
|
|
if (!m_pack_image_cache_key.was_ever_used)
|
|
return {};
|
|
|
|
// Imaged got evicted from the cache. Re-process it and retry.
|
|
ResourcePackUtils::process(*this);
|
|
return image(size);
|
|
}
|
|
|
|
std::pair<Version, Version> ResourcePack::compatibleVersions() const
|
|
{
|
|
if (!s_pack_format_versions.contains(m_pack_format)) {
|
|
return { {}, {} };
|
|
}
|
|
|
|
return s_pack_format_versions.constFind(m_pack_format).value();
|
|
}
|
|
|
|
std::pair<int, bool> ResourcePack::compare(const Resource& other, SortType type) const
|
|
{
|
|
auto const& cast_other = static_cast<ResourcePack const&>(other);
|
|
|
|
switch (type) {
|
|
default: {
|
|
auto res = Resource::compare(other, type);
|
|
if (res.first != 0)
|
|
return res;
|
|
}
|
|
case SortType::PACK_FORMAT: {
|
|
auto this_ver = packFormat();
|
|
auto other_ver = cast_other.packFormat();
|
|
|
|
if (this_ver > other_ver)
|
|
return { 1, type == SortType::PACK_FORMAT };
|
|
if (this_ver < other_ver)
|
|
return { -1, type == SortType::PACK_FORMAT };
|
|
}
|
|
}
|
|
return { 0, false };
|
|
}
|
|
|
|
bool ResourcePack::applyFilter(QRegularExpression filter) const
|
|
{
|
|
if (filter.match(description()).hasMatch())
|
|
return true;
|
|
|
|
if (filter.match(QString::number(packFormat())).hasMatch())
|
|
return true;
|
|
|
|
if (filter.match(compatibleVersions().first.toString()).hasMatch())
|
|
return true;
|
|
if (filter.match(compatibleVersions().second.toString()).hasMatch())
|
|
return true;
|
|
|
|
return Resource::applyFilter(filter);
|
|
}
|