💿🐜 Antkeeper source code https://antkeeper.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

88 lines
2.8 KiB

  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. #include "game/ant/gene/loader/gene-loader.hpp"
  20. #include "resources/resource-loader.hpp"
  21. #include "resources/resource-manager.hpp"
  22. #include "resources/json.hpp"
  23. #include "game/ant/gene/eyes.hpp"
  24. #include "render/model.hpp"
  25. #include <stdexcept>
  26. using namespace game::ant;
  27. static void deserialize_eyes_phene(phene::eyes& phene, const json& phene_element, resource_manager* resource_manager)
  28. {
  29. phene.present = false;
  30. phene.model = nullptr;
  31. phene.length = 0.0f;
  32. phene.width = 0.0f;
  33. phene.height = 0.0f;
  34. phene.ommatidia_count = 0;
  35. // Parse present
  36. if (auto element = phene_element.find("present"); element != phene_element.end())
  37. phene.present = element->get<bool>();
  38. if (phene.present)
  39. {
  40. // Load eyes model
  41. if (auto element = phene_element.find("model"); element != phene_element.end())
  42. phene.model = resource_manager->load<render::model>(element->get<std::string>());
  43. // Parse length
  44. if (auto element = phene_element.find("length"); element != phene_element.end())
  45. phene.length = element->get<float>();
  46. // Parse width
  47. if (auto element = phene_element.find("width"); element != phene_element.end())
  48. phene.width = element->get<float>();
  49. // Parse height
  50. if (auto element = phene_element.find("height"); element != phene_element.end())
  51. phene.height = element->get<float>();
  52. // Parse ommatidia count
  53. if (auto element = phene_element.find("ommatidia_count"); element != phene_element.end())
  54. phene.ommatidia_count = element->get<int>();
  55. }
  56. }
  57. template <>
  58. gene::eyes* resource_loader<gene::eyes>::load(resource_manager* resource_manager, PHYSFS_File* file, const std::filesystem::path& path)
  59. {
  60. // Load JSON data
  61. json* data = resource_loader<json>::load(resource_manager, file, path);
  62. // Validate gene file
  63. auto eyes_element = data->find("eyes");
  64. if (eyes_element == data->end())
  65. throw std::runtime_error("Invalid eyes gene.");
  66. // Allocate gene
  67. gene::eyes* eyes = new gene::eyes();
  68. // Deserialize gene
  69. gene::deserialize_gene(*eyes, &deserialize_eyes_phene, *eyes_element, resource_manager);
  70. // Free JSON data
  71. delete data;
  72. return eyes;
  73. }