💿🐜 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.

97 lines
3.8 KiB

  1. /*
  2. * Copyright (C) 2021 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 "resources/resource-loader.hpp"
  20. #include "resources/resource-manager.hpp"
  21. #include "resources/json.hpp"
  22. #include "game/ant/trait/waist.hpp"
  23. #include "render/model.hpp"
  24. #include <stdexcept>
  25. using namespace game::ant;
  26. template <>
  27. trait::waist* resource_loader<trait::waist>::load(resource_manager* resource_manager, PHYSFS_File* file, const std::filesystem::path& path)
  28. {
  29. // Load JSON data
  30. json* data = resource_loader<json>::load(resource_manager, file, path);
  31. // Validate trait file
  32. auto waist_element = data->find("waist");
  33. if (waist_element == data->end())
  34. throw std::runtime_error("Invalid waist trait.");
  35. // Allocate waist trait
  36. trait::waist* waist = new trait::waist();
  37. // Load waist model
  38. auto model_element = waist_element->find("model");
  39. if (model_element == waist_element->end())
  40. throw std::runtime_error("Waist trait doesn't specify waist model.");
  41. waist->model = resource_manager->load<render::model>(model_element->get<std::string>());
  42. // Parse waist spinescence
  43. waist->spinescence = 0.0f;
  44. if (auto spinescence_element = waist_element->find("spinescence"); spinescence_element != waist_element->end())
  45. waist->spinescence = spinescence_element->get<float>();
  46. // Parse waist petiole length
  47. waist->petiole_length = 0.0f;
  48. if (auto petiole_length_element = waist_element->find("petiole_length"); petiole_length_element != waist_element->end())
  49. waist->petiole_length = petiole_length_element->get<float>();
  50. // Parse waist petiole width
  51. waist->petiole_width = 0.0f;
  52. if (auto petiole_width_element = waist_element->find("petiole_width"); petiole_width_element != waist_element->end())
  53. waist->petiole_width = petiole_width_element->get<float>();
  54. // Parse waist petiole height
  55. waist->petiole_height = 0.0f;
  56. if (auto petiole_height_element = waist_element->find("petiole_height"); petiole_height_element != waist_element->end())
  57. waist->petiole_height = petiole_height_element->get<float>();
  58. // Parse waist postpetiole
  59. waist->postpetiole = false;
  60. if (auto postpetiole_element = waist_element->find("postpetiole"); postpetiole_element != waist_element->end())
  61. waist->postpetiole = postpetiole_element->get<bool>();
  62. waist->postpetiole_length = 0.0f;
  63. waist->postpetiole_width = 0.0f;
  64. waist->postpetiole_height = 0.0f;
  65. if (waist->postpetiole)
  66. {
  67. // Parse waist postpetiole length
  68. if (auto postpetiole_length_element = waist_element->find("postpetiole_length"); postpetiole_length_element != waist_element->end())
  69. waist->postpetiole_length = postpetiole_length_element->get<float>();
  70. // Parse waist postpetiole width
  71. if (auto postpetiole_width_element = waist_element->find("postpetiole_width"); postpetiole_width_element != waist_element->end())
  72. waist->postpetiole_width = postpetiole_width_element->get<float>();
  73. // Parse waist postpetiole height
  74. if (auto postpetiole_height_element = waist_element->find("postpetiole_height"); postpetiole_height_element != waist_element->end())
  75. waist->postpetiole_height = postpetiole_height_element->get<float>();
  76. }
  77. // Free JSON data
  78. delete data;
  79. return waist;
  80. }