OpenMiner/source/server/lua/loader/LuaBiomeLoader.cpp
2020-03-17 22:22:22 +01:00

150 lines
6.2 KiB
C++

/*
* =====================================================================================
*
* OpenMiner
*
* Copyright (C) 2018-2020 Unarelith, Quentin Bazin <openminer@unarelith.net>
* 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 <gk/core/Debug.hpp>
#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<std::string>();
Tree &tree = Registry::getInstance().registerTree(stringID);
tree.setLogBlockID(Registry::getInstance().getBlockFromStringID(table["log_block"]).id());
sol::object trunkHeightObject = table["trunk_height"];
if (trunkHeightObject.valid()) {
if (trunkHeightObject.get_type() == sol::type::table) {
sol::table trunkHeight = trunkHeightObject.as<sol::table>();
tree.setTrunkHeight(trunkHeight["min"], trunkHeight["max"]);
}
else
DEBUG("ERROR: For tree '" + stringID + "': trunk_height must be a table");
}
sol::object hasLeavesObject = table["has_leaves"];
if (hasLeavesObject.valid()) {
if (hasLeavesObject.get_type() == sol::type::boolean) {
tree.setHasLeaves(hasLeavesObject.as<bool>());
}
else
DEBUG("ERROR: For tree '" + stringID + "': has_leaves must be a boolean");
}
sol::object leavesBlockObject = table["leaves_block"];
if (leavesBlockObject.valid()) {
if (leavesBlockObject.get_type() == sol::type::string) {
std::string leavesBlock = leavesBlockObject.as<std::string>();
tree.setLeavesBlockID(Registry::getInstance().getBlockFromStringID(leavesBlock).id());
}
else
DEBUG("ERROR: For tree '" + stringID + "': leaves_block must be a string");
}
else if (tree.hasLeaves())
DEBUG("ERROR: 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>();
std::string label = table["name"].get<std::string>();
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"];
if (blocksObject.valid() && blocksObject.get_type() == sol::type::table) {
sol::table table = blocksObject.as<sol::table>();
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
DEBUG("ERROR: For '" + biome.stringID() + "': 'blocks' field must be a table");
}
inline void LuaBiomeLoader::loadTreePlacementEntries(Biome &biome, const sol::table &table) const {
sol::optional<sol::table> treeDefinitions = table["trees"];
if (treeDefinitions != sol::nullopt) {
for (const auto &it : treeDefinitions.value()) {
sol::table treeDefinition = it.second.as<sol::table>();
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<sol::table> floraDefinitions = table["flora"];
if (floraDefinitions != sol::nullopt) {
for (const auto &it : floraDefinitions.value()) {
sol::table floraDefinition = it.second.as<sol::table>();
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<sol::table> oreDefinitions = table["ore"];
if (oreDefinitions != sol::nullopt) {
for (const auto &it : oreDefinitions.value()) {
sol::table oreDefinition = it.second.as<sol::table>();
PlacementEntry::Ore &oreEntry = biome.addOre();
oreEntry.blockID = Registry::getInstance().getBlockFromStringID(oreDefinition["block"]).id();
oreEntry.probability = oreDefinition["probability"];
oreEntry.size = oreDefinition["size"];
}
}
}