Antkeeper  0.0.1
waist-loader.cpp
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2023 Christopher J. Howard
3  *
4  * This file is part of Antkeeper source code.
5  *
6  * Antkeeper source code is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * Antkeeper source code is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Antkeeper source code. If not, see <http://www.gnu.org/licenses/>.
18  */
19 
24 #include "game/ant/gene/waist.hpp"
25 #include <engine/render/model.hpp>
26 #include <stdexcept>
27 
28 using namespace ::ant;
29 
30 static void deserialize_waist_phene(phene::waist& phene, const json& phene_element, resource_manager* resource_manager)
31 {
32  phene.model = nullptr;
33  phene.petiole_present = false;
34  phene.petiole_length = 0.0f;
35  phene.petiole_width = 0.0f;
36  phene.petiole_height = 0.0f;
37  phene.petiole_spinescence = 0.0f;
38  phene.postpetiole_present = false;
39  phene.postpetiole_length = 0.0f;
40  phene.postpetiole_width = 0.0f;
41  phene.postpetiole_height = 0.0f;
42  phene.postpetiole_spinescence = 0.0f;
43 
44  // Load waist model
45  if (auto element = phene_element.find("model"); element != phene_element.end())
46  phene.model = resource_manager->load<render::model>(element->get<std::string>());
47 
48  // Parse petiole present
49  if (auto element = phene_element.find("petiole_present"); element != phene_element.end())
50  phene.petiole_present = element->get<bool>();
51 
52  // Parse postpetiole present
53  if (auto element = phene_element.find("postpetiole_present"); element != phene_element.end())
54  phene.postpetiole_present = element->get<bool>();
55 
56  if (phene.petiole_present)
57  {
58  // Parse petiole length
59  if (auto element = phene_element.find("petiole_length"); element != phene_element.end())
60  phene.petiole_length = element->get<float>();
61 
62  // Parse petiole width
63  if (auto element = phene_element.find("petiole_width"); element != phene_element.end())
64  phene.petiole_width = element->get<float>();
65 
66  // Parse petiole height
67  if (auto element = phene_element.find("petiole_height"); element != phene_element.end())
68  phene.petiole_height = element->get<float>();
69 
70  // Parse petiole spinescence
71  if (auto element = phene_element.find("petiole_spinescence"); element != phene_element.end())
72  phene.petiole_spinescence = element->get<float>();
73  }
74 
75  if (phene.postpetiole_present)
76  {
77  // Parse postpetiole length
78  if (auto element = phene_element.find("postpetiole_length"); element != phene_element.end())
79  phene.postpetiole_length = element->get<float>();
80 
81  // Parse postpetiole width
82  if (auto element = phene_element.find("postpetiole_width"); element != phene_element.end())
83  phene.postpetiole_width = element->get<float>();
84 
85  // Parse postpetiole height
86  if (auto element = phene_element.find("postpetiole_height"); element != phene_element.end())
87  phene.postpetiole_height = element->get<float>();
88 
89  // Parse postpetiole spinescence
90  if (auto element = phene_element.find("postpetiole_spinescence"); element != phene_element.end())
91  phene.postpetiole_spinescence = element->get<float>();
92  }
93 }
94 
95 template <>
96 gene::waist* resource_loader<gene::waist>::load(resource_manager* resource_manager, PHYSFS_File* file, const std::filesystem::path& path)
97 {
98  // Load JSON data
100 
101  // Validate gene file
102  auto waist_element = data->find("waist");
103  if (waist_element == data->end())
104  throw std::runtime_error("Invalid waist gene.");
105 
106  // Allocate gene
107  gene::waist* waist = new gene::waist();
108 
109  // Deserialize gene
110  gene::deserialize_gene(*waist, &deserialize_waist_phene, *waist_element, resource_manager);
111 
112  // Free JSON data
113  delete data;
114 
115  return waist;
116 }
static T * load(resource_manager *resourceManager, PHYSFS_File *file, const std::filesystem::path &path)
Loads resource data.
Loads resources.
T * load(const std::filesystem::path &path)
Loads the requested resource.
nlohmann::json json
JSON data.
Definition: json.hpp:26
void deserialize_gene(monophenic_gene< T > &gene, void(*deserialize_phene)(T &, const json &, resource_manager *), const json &gene_element, resource_manager *resource_manager)
Deserializes a gene.
Definition: gene-loader.hpp:43
polyphenic_gene< phene::waist > waist
Polyphenic waist gene.
Definition: gene/waist.hpp:30
Definition: caste.hpp:25