Skip to content

Commit

Permalink
Minor refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
MihailRis committed Dec 20, 2023
1 parent 3ad9034 commit e0aee76
Show file tree
Hide file tree
Showing 4 changed files with 36 additions and 9 deletions.
20 changes: 17 additions & 3 deletions src/content/ContentPack.cpp
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
#include "ContentPack.h"

#include <iostream>
#include <stdexcept>

#include "../coders/json.h"
#include "../files/files.h"
Expand All @@ -12,6 +11,20 @@ namespace fs = std::filesystem;
const std::string ContentPack::PACKAGE_FILENAME = "package.json";
const std::string ContentPack::CONTENT_FILENAME = "content.json";

contentpack_error::contentpack_error(
std::string packId,
std::filesystem::path folder,
std::string message)
: std::runtime_error(message), packId(packId), folder(folder) {
}

std::string contentpack_error::getPackId() const {
return packId;
}
std::filesystem::path contentpack_error::getFolder() const {
return folder;
}

std::filesystem::path ContentPack::getContentFile() const {
return folder/fs::path(CONTENT_FILENAME);
}
Expand All @@ -28,7 +41,7 @@ ContentPack ContentPack::read(std::filesystem::path folder) {
root->str("version", pack.version);
pack.folder = folder;
if (pack.id == "none")
throw std::runtime_error("content-pack id is none: "+folder.u8string());
throw contentpack_error(pack.id, folder, "content-pack id is none");
return pack;
}

Expand Down Expand Up @@ -60,7 +73,8 @@ std::vector<std::string> ContentPack::worldPacksList(fs::path folder) {
fs::path ContentPack::findPack(const EnginePaths* paths, std::string name) {
auto folder = paths->getResources() / fs::path("content") / fs::path(name);
if (!fs::is_directory(folder)) {
throw std::runtime_error("could not to find pack '"+name+"'");
throw contentpack_error(name, folder,
"could not to find pack '"+name+"'");
}
return folder;
}
13 changes: 13 additions & 0 deletions src/content/ContentPack.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,23 @@

#include <string>
#include <vector>
#include <stdexcept>
#include <filesystem>

class EnginePaths;

class contentpack_error : public std::runtime_error {
std::string packId;
std::filesystem::path folder;
public:
contentpack_error(std::string packId,
std::filesystem::path folder,
std::string message);

std::string getPackId() const;
std::filesystem::path getFolder() const;
};

struct ContentPack {
std::string id = "none";
std::string title = "untitled";
Expand Down
1 change: 0 additions & 1 deletion src/engine.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -203,5 +203,4 @@ void Engine::loadAllPacks() {
auto resdir = paths->getResources();
contentPacks.clear();
ContentPack::scan(resdir/fs::path("content"), contentPacks);
loadContent();
}
11 changes: 6 additions & 5 deletions src/frontend/menu.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -156,16 +156,16 @@ void open_world(std::string name, Engine* engine) {
packs.clear();
auto packnames = ContentPack::worldPacksList(folder);
for (auto name : packnames) {
fs::path packfolder;
try {
packfolder = ContentPack::findPack(paths, name);
} catch (std::runtime_error& error) {
fs::path packfolder = ContentPack::findPack(paths, name);
packs.push_back(ContentPack::read(packfolder));
} catch (contentpack_error& error) {
// could not to find or read pack
guiutil::alert(engine->getGUI(),
langs::get(L"error.pack-not-found")+
L": "+util::str2wstr_utf8(name));
L": "+util::str2wstr_utf8(error.getPackId()));
return;
}
packs.push_back(ContentPack::read(packfolder));
}
engine->loadContent();

Expand Down Expand Up @@ -291,6 +291,7 @@ void create_new_world_panel(Engine* engine, PagesControl* menu) {
fs::create_directories(folder);

engine->loadAllPacks();
engine->loadContent();
Level* level = World::create(nameutf8,
folder,
seed,
Expand Down

0 comments on commit e0aee76

Please sign in to comment.