/* * ===================================================================================== * * OpenMiner * * Copyright (C) 2018-2020 Unarelith, Quentin Bazin * Copyright (C) 2019-2020 the OpenMiner contributors (see CONTRIBUTORS.md) * * This file is part of OpenMiner. * * OpenMiner is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * OpenMiner 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with OpenMiner; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * * ===================================================================================== */ #include #include "LuaBiomeLoader.hpp" #include "LuaMod.hpp" #include "Registry.hpp" void LuaBiomeLoader::loadTree(const sol::table &table) const { std::string stringID = m_mod.id() + ":" + table["id"].get(); Tree &tree = Registry::getInstance().registerTree(stringID); tree.setLogBlockID(Registry::getInstance().getBlockFromStringID(table["log_block"]).id()); sol::object trunkHeightObject = table["trunk_height"].get(); if (trunkHeightObject.valid()) { if (trunkHeightObject.get_type() == sol::type::table) { sol::table trunkHeight = trunkHeightObject.as(); tree.setTrunkHeight(trunkHeight["min"], trunkHeight["max"]); } else gkError() << "For tree" << stringID << ": 'trunk_height' must be a table"; } sol::object hasLeavesObject = table["has_leaves"].get(); if (hasLeavesObject.valid()) { if (hasLeavesObject.get_type() == sol::type::boolean) { tree.setHasLeaves(hasLeavesObject.as()); } else gkError() << "For tree" << stringID << ": 'has_leaves' must be a boolean"; } sol::object leavesBlockObject = table["leaves_block"].get(); if (leavesBlockObject.valid()) { if (leavesBlockObject.get_type() == sol::type::string) { std::string leavesBlock = leavesBlockObject.as(); tree.setLeavesBlockID(Registry::getInstance().getBlockFromStringID(leavesBlock).id()); } else gkError() << "For tree" << stringID << ": 'leaves_block must be a string"; } else if (tree.hasLeaves()) gkError() << "For tree" << stringID << ": 'leaves_block' must be defined if has_leaves == true"; } void LuaBiomeLoader::loadBiome(const sol::table &table) const { std::string stringID = m_mod.id() + ":" + table["id"].get(); std::string label = table["name"].get(); Biome &biome = Registry::getInstance().registerBiome(stringID, label); loadBiomeParameters(biome, table); loadBiomeBlocks(biome, table); loadTreePlacementEntries(biome, table); loadFloraPlacementEntries(biome, table); loadOrePlacementEntries(biome, table); } inline void LuaBiomeLoader::loadBiomeParameters(Biome &biome, const sol::table &table) const { // TODO eventually a WorldType could have a list of biome parameter names in order, // and we could use those as the ordered keys. // Currently hardcoding "temperature" and "precipitation" to get something functional. biome.addParameter(table["params"]["temperature"]); biome.addParameter(table["params"]["precipitation"]); } inline void LuaBiomeLoader::loadBiomeBlocks(Biome &biome, const sol::table &table) const { sol::object blocksObject = table["blocks"].get(); if (blocksObject.valid() && blocksObject.get_type() == sol::type::table) { sol::table table = blocksObject.as(); biome.setTopBlockID(Registry::getInstance().getBlockFromStringID(table["top"]).id()); biome.setGroundBlockID(Registry::getInstance().getBlockFromStringID(table["ground"]).id()); biome.setDeepBlockID(Registry::getInstance().getBlockFromStringID(table["deep"]).id()); biome.setBeachBlockID(Registry::getInstance().getBlockFromStringID(table["beach"]).id()); biome.setLiquidBlockID(Registry::getInstance().getBlockFromStringID(table["liquid"]).id()); biome.setPortalBlockID(Registry::getInstance().getBlockFromStringID(table["portal"]).id()); biome.setPortalFrameBlockID(Registry::getInstance().getBlockFromStringID(table["portal_frame"]).id()); } else gkError() << "For" << biome.stringID() << ": 'blocks' field must be a table"; } inline void LuaBiomeLoader::loadTreePlacementEntries(Biome &biome, const sol::table &table) const { sol::optional treeDefinitions = table["trees"]; if (treeDefinitions != sol::nullopt) { for (const auto &it : treeDefinitions.value()) { sol::table treeDefinition = it.second.as(); PlacementEntry::Tree &treeEntry = biome.addTree(); treeEntry.treeID = Registry::getInstance().getTreeFromStringID(treeDefinition["type"]).id(); treeEntry.probability = treeDefinition["probability"]; } } } inline void LuaBiomeLoader::loadFloraPlacementEntries(Biome &biome, const sol::table &table) const { sol::optional floraDefinitions = table["flora"]; if (floraDefinitions != sol::nullopt) { for (const auto &it : floraDefinitions.value()) { sol::table floraDefinition = it.second.as(); PlacementEntry::Flora &floraEntry = biome.addFlora(); floraEntry.blockID = Registry::getInstance().getBlockFromStringID(floraDefinition["block"]).id(); floraEntry.spawnsOnBlockID = Registry::getInstance().getBlockFromStringID(floraDefinition["spawns_on"]).id(); floraEntry.probability = floraDefinition["probability"]; } } } inline void LuaBiomeLoader::loadOrePlacementEntries(Biome &biome, const sol::table &table) const { sol::optional oreDefinitions = table["ores"]; if (oreDefinitions != sol::nullopt) { for (const auto &it : oreDefinitions.value()) { sol::table oreDefinition = it.second.as(); PlacementEntry::Ore &oreEntry = biome.addOre(); oreEntry.blockID = Registry::getInstance().getBlockFromStringID(oreDefinition["block"]).id(); oreEntry.probability = oreDefinition["probability"]; oreEntry.size = oreDefinition["size"]; std::unordered_map genTypes{ {"random_walk", PlacementEntry::Ore::Gen::RandomWalk}, {"flood_fill", PlacementEntry::Ore::Gen::FloodFill}, }; oreEntry.genType = genTypes.at(oreDefinition["gen_type"].get()); } } }