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

75 lines
2.1 KiB

  1. /*
  2. * Copyright (C) 2017-2019 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 "resource-loader.hpp"
  20. #include "resource-manager.hpp"
  21. #include "string-table.hpp"
  22. #include <sstream>
  23. #include <stdexcept>
  24. #include <emergent/emergent.hpp>
  25. using namespace Emergent;
  26. template <>
  27. ParameterDict* ResourceLoader<ParameterDict>::load(ResourceManager* resourceManager, std::istream* is)
  28. {
  29. // Load string table from input stream
  30. StringTable* table = ResourceLoader<StringTable>::load(resourceManager, is);
  31. // Ensure table is not empty.
  32. if (!table || table->empty())
  33. {
  34. delete table;
  35. return nullptr;
  36. }
  37. // Create new parameter dict
  38. ParameterDict* dict = new ParameterDict();
  39. // Load parameters from table rows
  40. for (const StringTableRow& row: *table)
  41. {
  42. // Skip comments, blank parameter names, and rows that don't have exactly two columns
  43. if (row.size() != 2 || row[0].empty() || row[0][0] == '#')
  44. {
  45. continue;
  46. }
  47. // Add parameter to dict
  48. dict->set(row[0], row[1]);
  49. }
  50. return dict;
  51. }
  52. template <>
  53. void ResourceLoader<ParameterDict>::save(ResourceManager* resourceManager, std::ostream* os, const ParameterDict* dict)
  54. {
  55. // Build string table
  56. StringTable table;
  57. const std::map<std::string, std::string>* parameters = dict->getParameters();
  58. for (auto it = parameters->begin(); it != parameters->end(); ++it)
  59. {
  60. table.push_back({it->first, it->second});
  61. }
  62. // Save string table
  63. ResourceLoader<StringTable>::save(resourceManager, os, &table);
  64. }