Skip to content

Commit

Permalink
split problems into load problems and outdated GD version
Browse files Browse the repository at this point in the history
  • Loading branch information
HJfod committed Nov 10, 2024
1 parent c9afa75 commit 12e8bbb
Show file tree
Hide file tree
Showing 13 changed files with 65 additions and 25 deletions.
3 changes: 2 additions & 1 deletion loader/include/Geode/loader/Loader.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,8 @@ namespace geode {
Mod* getLoadedMod(std::string const& id) const;
std::vector<Mod*> getAllMods();
std::vector<LoadProblem> getAllProblems() const;
std::vector<LoadProblem> getProblems() const;
std::vector<LoadProblem> getLoadProblems() const;
std::vector<LoadProblem> getOutdated() const;
std::vector<LoadProblem> getRecommendations() const;

/**
Expand Down
3 changes: 2 additions & 1 deletion loader/include/Geode/loader/Mod.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -446,7 +446,8 @@ namespace geode {
bool isLoggingEnabled() const;
void setLoggingEnabled(bool enabled);

bool hasProblems() const;
bool targetsOutdatedGDVersion() const;
bool hasLoadProblems() const;
std::vector<LoadProblem> getAllProblems() const;
std::vector<LoadProblem> getProblems() const;
std::vector<LoadProblem> getRecommendations() const;
Expand Down
3 changes: 1 addition & 2 deletions loader/src/hooks/MenuLayer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -83,13 +83,12 @@ struct CustomMenuLayer : Modify<CustomMenuLayer, MenuLayer> {
}

// show if some mods failed to load
if (Loader::get()->getProblems().size()) {
if (Loader::get()->getLoadProblems().size()) {
static bool shownProblemPopup = false;
if (!shownProblemPopup) {
shownProblemPopup = true;
Notification::create("There were errors - see Geode page!", NotificationIcon::Error)->show();
}

if (m_fields->m_geodeButton) {
m_fields->m_exclamation = CCSprite::createWithSpriteFrameName("exMark_001.png");
m_fields->m_exclamation->setPosition(m_fields->m_geodeButton->getContentSize() - ccp(10, 10));
Expand Down
2 changes: 1 addition & 1 deletion loader/src/internal/FixModIssues.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ class AutoFixStatus final {

public:
void start() {
for (auto problem : Loader::get()->getProblems()) {
for (auto problem : Loader::get()->getAllProblems()) {
switch (problem.type) {
// Errors where the correct solution is to just delete the invalid .geode package
case LoadProblem::Type::InvalidFile:
Expand Down
6 changes: 4 additions & 2 deletions loader/src/internal/crashlog.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,8 @@ void crashlog::printGeodeInfo(std::stringstream& stream) {
<< "Loader Commit: " << about::getLoaderCommitHash() << "\n"
<< "Bindings Commit: " << about::getBindingsCommitHash() << "\n"
<< "Installed mods: " << Loader::get()->getAllMods().size() << "\n"
<< "Problems: " << Loader::get()->getProblems().size() << "\n";
<< "Outdated mods: " << Loader::get()->getOutdated().size() << "\n"
<< "Problems: " << Loader::get()->getLoadProblems().size() << "\n";
}

void crashlog::printMods(std::stringstream& stream) {
Expand All @@ -44,7 +45,8 @@ void crashlog::printMods(std::stringstream& stream) {
stream << fmt::format("{} | [{}] {}\n",
mod->isCurrentlyLoading() ? "o"sv :
mod->isEnabled() ? "x"sv :
mod->hasProblems() ? "!"sv : // thank you for this bug report
mod->hasLoadProblems() ? "!"sv : // thank you for this bug report
mod->targetsOutdatedGDVersion() ? "*"sv : // thank you very much for this bug report
mod->shouldLoad() ? "~"sv :
" "sv,
mod->getVersion().toVString(), mod->getID()
Expand Down
14 changes: 12 additions & 2 deletions loader/src/loader/Loader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -68,18 +68,28 @@ std::vector<Mod*> Loader::getAllMods() {
std::vector<LoadProblem> Loader::getAllProblems() const {
return m_impl->getProblems();
}
std::vector<LoadProblem> Loader::getProblems() const {
std::vector<LoadProblem> Loader::getLoadProblems() const {
std::vector<LoadProblem> result;
for (auto problem : this->getAllProblems()) {
if (
problem.type != LoadProblem::Type::Recommendation &&
problem.type != LoadProblem::Type::Suggestion
problem.type != LoadProblem::Type::Suggestion &&
problem.type != LoadProblem::Type::UnsupportedVersion
) {
result.push_back(problem);
}
}
return result;
}
std::vector<LoadProblem> Loader::getOutdated() const {
std::vector<LoadProblem> result;
for (auto problem : this->getAllProblems()) {
if (problem.type == LoadProblem::Type::UnsupportedVersion) {
result.push_back(problem);
}
}
return result;
}
std::vector<LoadProblem> Loader::getRecommendations() const {
std::vector<LoadProblem> result;
for (auto problem : this->getAllProblems()) {
Expand Down
15 changes: 12 additions & 3 deletions loader/src/loader/Mod.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -252,8 +252,16 @@ bool Mod::hasSavedValue(std::string_view const key) {
return this->getSaveContainer().contains(key);
}

bool Mod::hasProblems() const {
return m_impl->hasProblems();
bool Mod::hasLoadProblems() const {
return m_impl->hasLoadProblems();
}
bool Mod::targetsOutdatedGDVersion() const {
for (auto problem : this->getAllProblems()) {
if (problem.type == LoadProblem::Type::UnsupportedVersion) {
return true;
}
}
return false;
}
std::vector<LoadProblem> Mod::getAllProblems() const {
return m_impl->getProblems();
Expand All @@ -263,7 +271,8 @@ std::vector<LoadProblem> Mod::getProblems() const {
for (auto problem : this->getAllProblems()) {
if (
problem.type != LoadProblem::Type::Recommendation &&
problem.type != LoadProblem::Type::Suggestion
problem.type != LoadProblem::Type::Suggestion &&
problem.type != LoadProblem::Type::UnsupportedVersion
) {
result.push_back(problem);
}
Expand Down
14 changes: 9 additions & 5 deletions loader/src/loader/ModImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -708,11 +708,15 @@ bool Mod::Impl::isCurrentlyLoading() const {
return m_isCurrentlyLoading;
}

bool Mod::Impl::hasProblems() const {
for (auto const& item : m_problems) {
if (item.type <= LoadProblem::Type::Recommendation)
continue;
return true;
bool Mod::Impl::hasLoadProblems() const {
for (auto const& problem : m_problems) {
if (
problem.type != LoadProblem::Type::Recommendation &&
problem.type != LoadProblem::Type::Suggestion &&
problem.type != LoadProblem::Type::UnsupportedVersion
) {
return true;
}
}
return false;
}
Expand Down
2 changes: 1 addition & 1 deletion loader/src/loader/ModImpl.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,7 @@ namespace geode {

std::vector<LoadProblem> getProblems() const;

bool hasProblems() const;
bool hasLoadProblems() const;
bool shouldLoad() const;
bool isCurrentlyLoading() const;
};
Expand Down
13 changes: 9 additions & 4 deletions loader/src/ui/mods/list/ModItem.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -185,7 +185,7 @@ bool ModItem::init(ModSource&& source) {
m_viewMenu->addChild(m_enableToggle);
m_viewMenu->updateLayout();
}
if (mod->hasProblems()) {
if (mod->hasLoadProblems() || mod->targetsOutdatedGDVersion()) {
auto viewErrorSpr = createGeodeCircleButton(
CCSprite::createWithSpriteFrameName("exclamation.png"_spr), 1.f,
CircleBaseSize::Small
Expand Down Expand Up @@ -410,9 +410,14 @@ void ModItem::updateState() {
m_titleContainer->updateLayout();

// If there were problems, tint the BG red
if (m_source.asMod() && m_source.asMod()->hasProblems()) {
m_bg->setColor("mod-list-errors-found"_cc3b);
m_bg->setOpacity(isGeodeTheme() ? 25 : 90);
if (m_source.asMod()) {
if (m_source.asMod()->hasLoadProblems()) {
m_bg->setColor("mod-list-errors-found"_cc3b);
m_bg->setOpacity(isGeodeTheme() ? 25 : 90);
}
if (m_source.asMod()->targetsOutdatedGDVersion()) {
m_bg->setOpacity(isGeodeTheme() ? 0 : 0);
}
}

// Highlight item via BG if it wants to restart for extra UI attention
Expand Down
4 changes: 2 additions & 2 deletions loader/src/ui/mods/list/ModList.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@ bool ModList::init(ModListSource* src, CCSize const& size) {

m_topContainer->addChild(m_updateAllContainer);

if (Loader::get()->getProblems().size()) {
if (Loader::get()->getLoadProblems().size()) {
m_errorsContainer = CCNode::create();
m_errorsContainer->setID("errors-container");
m_errorsContainer->ignoreAnchorPointForPosition(false);
Expand Down Expand Up @@ -549,7 +549,7 @@ void ModList::updateTopContainer() {

// If there are errors, show the error banner
if (m_errorsContainer) {
auto noErrors = Loader::get()->getProblems().empty();
auto noErrors = Loader::get()->getLoadProblems().empty();
m_errorsContainer->setVisible(!noErrors);
}

Expand Down
10 changes: 9 additions & 1 deletion loader/src/ui/mods/sources/InstalledModListSource.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,11 @@ bool InstalledModsQuery::preCheck(ModSource const& src) const {
return false;
}
// If only errors requested, only show mods with errors (duh)
if (type == InstalledModListType::OnlyOutdated) {
return src.asMod()->targetsOutdatedGDVersion();
}
if (type == InstalledModListType::OnlyErrors) {
return src.asMod()->hasProblems();
return src.asMod()->hasLoadProblems();
}
return true;
}
Expand Down Expand Up @@ -59,6 +62,11 @@ InstalledModListSource* InstalledModListSource::get(InstalledModListType type) {
static auto inst = new InstalledModListSource(InstalledModListType::OnlyErrors);
return inst;
} break;

case InstalledModListType::OnlyOutdated: {
static auto inst = new InstalledModListSource(InstalledModListType::OnlyOutdated);
return inst;
} break;
}
}

Expand Down
1 change: 1 addition & 0 deletions loader/src/ui/mods/sources/ModListSource.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,7 @@ enum class InstalledModListType {
All,
OnlyUpdates,
OnlyErrors,
OnlyOutdated,
};
struct InstalledModsQuery final : public LocalModsQueryBase {
InstalledModListType type = InstalledModListType::All;
Expand Down

0 comments on commit 12e8bbb

Please sign in to comment.