osb/source/game/StarStatisticsDatabase.cpp

94 lines
2.8 KiB
C++
Raw Normal View History

2023-06-20 14:33:09 +10:00
#include "StarStatisticsDatabase.hpp"
#include "StarJsonExtra.hpp"
namespace Star {
StatisticsDatabase::StatisticsDatabase() : m_cacheMutex(), m_eventCache() {
auto assets = Root::singleton().assets();
2024-03-15 21:28:11 +11:00
auto& eventFiles = assets->scanExtension("event");
2023-06-20 14:33:09 +10:00
assets->queueJsons(eventFiles);
2024-03-15 21:28:11 +11:00
auto& achievementFiles = assets->scanExtension("achievement");
2023-06-20 14:33:09 +10:00
assets->queueJsons(achievementFiles);
2024-03-15 21:28:11 +11:00
for (auto& file : eventFiles) {
2023-06-20 14:33:09 +10:00
try {
String name = assets->json(file).getString("eventName");
if (m_eventPaths.contains(name))
2023-06-27 20:23:44 +10:00
Logger::error("Event {} defined twice, second time from {}", name, file);
2023-06-20 14:33:09 +10:00
else
m_eventPaths[name] = file;
} catch (std::exception const& e) {
2023-06-27 20:23:44 +10:00
Logger::error("Error loading event file {}: {}", file, outputException(e, true));
2023-06-20 14:33:09 +10:00
}
}
2024-03-15 21:28:11 +11:00
for (auto& file : achievementFiles) {
2023-06-20 14:33:09 +10:00
try {
Json achievement = assets->json(file);
String name = achievement.getString("name");
if (m_achievementPaths.contains(name))
2023-06-27 20:23:44 +10:00
Logger::error("Achievement {} defined twice, second time from {}", name, file);
2023-06-20 14:33:09 +10:00
else
m_achievementPaths[name] = file;
for (Json const& stat : achievement.getArray("triggers", {})) {
m_statAchievements[stat.toString()].append(name);
}
} catch (std::exception const& e) {
2023-06-27 20:23:44 +10:00
Logger::error("Error loading achievement file {}: {}", file, outputException(e, true));
2023-06-20 14:33:09 +10:00
}
}
}
StatEventPtr StatisticsDatabase::event(String const& name) const {
MutexLocker locker(m_cacheMutex);
return m_eventCache.get(name, [this](String const& name) -> StatEventPtr {
if (auto path = m_eventPaths.maybe(name))
return readEvent(*path);
return {};
});
}
AchievementPtr StatisticsDatabase::achievement(String const& name) const {
MutexLocker locker(m_cacheMutex);
return m_achievementCache.get(name, [this](String const& name) -> AchievementPtr {
if (auto path = m_achievementPaths.maybe(name))
return readAchievement(*path);
return {};
});
}
StringList StatisticsDatabase::allAchievements() const {
return m_achievementPaths.keys();
}
StringList StatisticsDatabase::achievementsForStat(String const& statName) const {
return m_statAchievements.value(statName);
}
StatEventPtr StatisticsDatabase::readEvent(String const& path) {
auto assets = Root::singleton().assets();
Json config = assets->json(path);
return make_shared<StatEvent>(StatEvent {
config.getString("eventName"),
jsonToStringList(config.get("scripts")),
config
});
}
AchievementPtr StatisticsDatabase::readAchievement(String const& path) {
auto assets = Root::singleton().assets();
Json config = assets->json(path);
return make_shared<Achievement>(Achievement {
config.getString("name"),
jsonToStringList(config.get("triggers")),
jsonToStringList(config.get("scripts")),
config
});
}
}