| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180 |
- #include "RecipieLoader.h"
- #include <Datei.h>
- #include <iostream>
- #include <Logging.h>
- #include <stdexcept>
- #include "Game.h"
- #include "ItemType.h"
- #include "JsonUtils.h"
- using namespace Framework::JSON;
- using namespace Framework::Validator;
- RecipieLoader::RecipieLoader()
- : Framework::ReferenceCounter()
- {}
- RecipieLoader::~RecipieLoader() {}
- void RecipieLoader::loadRecipies(const char* path)
- {
- DataValidator* validator
- = Framework::Validator::DataValidator::buildForArray()
- ->addAcceptedTypeInArray(Game::INSTANCE->zTypeRegistry()
- ->getValidator<RecipieGroupConfig>())
- ->removeInvalidEntries()
- ->finishArray();
- loadAllJsonsFromDirectory(Framework::Text(path) + "/recipieGroups",
- [this, &validator](JSONValue* zJson, Framework::Text path) {
- Framework::Logging::info()
- << "loading recipie groups from '" << path << "'";
- Framework::RCArray<ValidationResult> invalidParts;
- JSONValue* valid = validator->getValidParts(zJson, &invalidParts);
- for (ValidationResult* invalidPart : invalidParts)
- {
- Framework::Logging::error() << invalidPart->getInvalidInfo();
- }
- int count = 0;
- if (valid)
- {
- for (JSONValue* value : *valid->asArray())
- {
- RecipieGroupConfig* recipieGroup
- = Game::INSTANCE->zTypeRegistry()
- ->fromJson<RecipieGroupConfig>(value);
- if (recipieGroup)
- {
- groupConfigs.add(recipieGroup);
- count++;
- }
- }
- }
- Framework::Logging::info()
- << count << " recipie groups were loaded.";
- });
- Framework::JSON::JSONObject* schema = validator->getJsonSchema();
- Framework::Datei syntaxFile;
- syntaxFile.setDatei("data/syntax/schema/recipieGroups.json");
- syntaxFile.erstellen();
- syntaxFile.open(Framework::Datei::Style::schreiben);
- syntaxFile.schreibe(schema->toString(), schema->toString().getLength());
- syntaxFile.close();
- schema->release();
- validator->release();
- validator
- = Framework::Validator::DataValidator::buildForArray()
- ->addAcceptedTypeInArray(
- Game::INSTANCE->zTypeRegistry()->getValidator<Recipie>())
- ->removeInvalidEntries()
- ->finishArray();
- loadAllJsonsFromDirectory(Framework::Text(path) + "/recipies",
- [this, &validator](JSONValue* zJson, Framework::Text path) {
- Framework::Logging::info()
- << "loading recipies from '" << path << "'";
- Framework::RCArray<ValidationResult> invalidParts;
- JSONValue* valid = validator->getValidParts(zJson, &invalidParts);
- for (ValidationResult* invalidPart : invalidParts)
- {
- Framework::Logging::error() << invalidPart->getInvalidInfo();
- }
- int count = 0;
- if (valid)
- {
- for (JSONValue* value : *valid->asArray())
- {
- Recipie* recipie
- = Game::INSTANCE->zTypeRegistry()->fromJson<Recipie>(
- value);
- if (recipie)
- {
- Framework::Text group = recipie->getGroupName();
- RecipieList* list = zRecipieList(group);
- if (!list)
- {
- registerRecipieList(group);
- list = zRecipieList(group);
- }
- list->addRecipie(recipie);
- count++;
- }
- }
- }
- Framework::Logging::info() << count << " recipies were loaded.";
- });
- schema = validator->getJsonSchema();
- syntaxFile.setDatei("data/syntax/schema/recipies.json");
- syntaxFile.erstellen();
- syntaxFile.open(Framework::Datei::Style::schreiben);
- syntaxFile.schreibe(schema->toString(), schema->toString().getLength());
- syntaxFile.close();
- schema->release();
- validator->release();
- for (RecipieList* list : lists)
- {
- bool found = 0;
- for (RecipieGroupConfig* groupConfig : groupConfigs)
- {
- if (list->getName().istGleich(groupConfig->getGroupName()))
- {
- found = 1;
- break;
- }
- }
- if (!found)
- {
- Framework::Logging::warning()
- << "Recipie list '" << list->getName()
- << "' has no group config. The recipies can not be viewed by "
- "the client.";
- }
- }
- }
- RecipieList* RecipieLoader::zRecipieList(const char* name) const
- {
- for (RecipieList* l : lists)
- {
- if (l->getName().istGleich(name)) return l;
- }
- return 0;
- }
- void RecipieLoader::registerRecipieList(const char* name)
- {
- if (zRecipieList(name))
- throw new std::invalid_argument("the recipie list already exists");
- lists.add(new RecipieList(name));
- }
- Framework::Text RecipieLoader::getCrafingUIML(int itemTypeId)
- {
- Framework::Text result = "<dialog id=\"crafting_";
- result.append() << itemTypeId << "\"><craftingRecipies>";
- for (RecipieList* list : lists)
- {
- Framework::RCArray<Recipie> recipies;
- list->findRecipies(itemTypeId, recipies);
- if (recipies.getEintragAnzahl() > 0)
- {
- for (RecipieGroupConfig* groupConfig : groupConfigs)
- {
- if (list->getName().istGleich(groupConfig->getGroupName()))
- {
- result.append() << "<craftingRecipieGroup name=\""
- << list->getName() << "\" itemIcon=\""
- << groupConfig->getIconItemType() << "\">";
- for (Recipie* recipie : recipies)
- {
- result += recipie->getRecipieUIML();
- }
- result += "</craftingRecipieGroup>";
- break;
- }
- }
- }
- }
- result += "</craftingRecipies></dialog>";
- return result;
- }
|