/* * * Copyright (C) 2024 Brett Terpstra * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include #include #include #include #include #include using json = nlohmann::json; template T load_with_default(const json& data, std::string_view key, T def) { if (data.contains(key)) return data[key].get(); return def; } std::optional loader_t::load_for(engine_t& engine, const blt::gfx::window_data& window_data, std::string_view path, std::optional save_path) { auto& graph = engine.graph; static std::random_device dev; std::uniform_real_distribution pos_x_dist(0.0, static_cast(window_data.width)); std::uniform_real_distribution pos_y_dist(0.0, static_cast(window_data.height)); if (save_path && std::filesystem::exists(*save_path)) path = *save_path; if (!std::filesystem::exists(path)) { BLT_WARN("Unable to load graph file!"); return {}; } std::ifstream file{std::string(path)}; json data = json::parse(file); loader_t loader; if (data.contains("textures")) { for (const auto& texture : data["textures"]) { auto texture_path = texture["path"].get(); auto texture_key = load_with_default(texture, "name", texture_path); loader.textures.emplace_back(texture_key, texture_path); } } if (data.contains("nodes")) { graph.nodes.clear(); for (const auto& node : data["nodes"]) { auto x = static_cast(load_with_default(node, "x", pos_x_dist(dev))); auto y = static_cast(load_with_default(node, "y", pos_y_dist(dev))); auto size = static_cast(load_with_default(node, "size", static_cast(conf::POINT_SIZE))); auto name = load_with_default(node, "name", "unnamed"); graph.names_to_node.insert({name, static_cast(graph.nodes.size())}); graph.nodes.emplace_back(blt::gfx::point2d_t{x, y, size}); graph.nodes.back().name = std::move(name); } } if (data.contains("connections")) { graph.edges.clear(); graph.connected_nodes.clear(); } return loader; } void loader_t::save_for(engine_t& engine, const loader_t& loader, std::string_view path) { }