config.hpp 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /**
  2. * @file
  3. * @author Caleb Fangmeier <caleb@fangmeier.tech>
  4. * @version 0.1
  5. *
  6. * @section LICENSE
  7. *
  8. *
  9. * MIT License
  10. *
  11. * Copyright (c) 2017 Caleb Fangmeier
  12. *
  13. * Permission is hereby granted, free of charge, to any person obtaining a copy
  14. * of this software and associated documentation files (the "Software"), to deal
  15. * in the Software without restriction, including without limitation the rights
  16. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  17. * copies of the Software, and to permit persons to whom the Software is
  18. * furnished to do so, subject to the following conditions:
  19. *
  20. * The above copyright notice and this permission notice shall be included in all
  21. * copies or substantial portions of the Software.
  22. *
  23. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  24. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  25. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  26. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  27. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  28. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  29. * SOFTWARE.
  30. *
  31. */
  32. #ifndef config_hpp
  33. #define config_hpp
  34. #include <string>
  35. #include <fstream>
  36. #include <sstream>
  37. #include "yaml-cpp/yaml.h"
  38. namespace fv_util {
  39. struct DataFileDescriptor {
  40. std::string filename;
  41. std::string label;
  42. std::string category;
  43. int file_number;
  44. int n_events;
  45. DataFileDescriptor() : filename(""), label(""), category(""), file_number(-1), n_events(-1) {}
  46. DataFileDescriptor(const std::string filename, const std::string label, const std::string category,
  47. const int n_events)
  48. : filename(filename), label(label), category(category), file_number(-1), n_events(n_events) {}
  49. DataFileDescriptor(const std::string filename, const std::string label, const std::string category,
  50. const int file_number, const int n_events)
  51. : filename(filename), label(label), category(category), file_number(file_number), n_events(n_events) {}
  52. };
  53. }
  54. namespace YAML {
  55. template<>
  56. struct convert<fv_util::DataFileDescriptor> {
  57. static Node encode(const fv_util::DataFileDescriptor &rhs) {
  58. Node node;
  59. node["filename"] = rhs.filename;
  60. node["label"] = rhs.label;
  61. node["category"] = rhs.category;
  62. node["n_events"] = rhs.n_events;
  63. return node;
  64. }
  65. static bool decode(const Node &node, fv_util::DataFileDescriptor &rhs) {
  66. if (!node.IsMap()) {
  67. return false;
  68. }
  69. if (!node["filename"]) return false;
  70. rhs.filename = node["filename"].as<std::string>();
  71. if (node["label"]) rhs.label = node["label"].as<std::string>();
  72. if (node["category"]) rhs.category = node["category"].as<std::string>();
  73. if (node["n_events"]) rhs.n_events = node["n_events"].as<int>();
  74. return true;
  75. }
  76. };
  77. }
  78. namespace fv_util {
  79. class Config {
  80. private:
  81. std::string input_filename;
  82. YAML::Node root;
  83. public:
  84. Config()
  85. : root(), input_filename("") {}
  86. Config(const Config &c)
  87. : root(c.root), input_filename(c.input_filename) {}
  88. Config(const std::string &input_filename)
  89. : root(YAML::LoadFile(input_filename)),
  90. input_filename(input_filename) {}
  91. template<typename KEY_TYPE>
  92. YAML::Node get(const KEY_TYPE &key) {
  93. auto val = root[key];
  94. return val;
  95. }
  96. template<typename T>
  97. void update_key(const std::string &key, const T &val) {
  98. root[key] = val;
  99. }
  100. std::string as_string() {
  101. std::stringstream config;
  102. std::ifstream s(input_filename);
  103. for (std::string line; std::getline(s, line);) {
  104. config << line << std::endl;
  105. }
  106. return config.str();
  107. }
  108. size_t get_max_events() {
  109. YAML::Node max_events = root["max-events"];
  110. if (!max_events) {
  111. return 0;
  112. }
  113. return max_events.as<size_t>();
  114. }
  115. bool get_debug() {
  116. YAML::Node debug_node = root["debug"];
  117. if (!debug_node) {
  118. return false;
  119. }
  120. return debug_node.as<bool>();
  121. }
  122. std::string get_output_filename() {
  123. YAML::Node output_file = root["output-file"];
  124. if (output_file) {
  125. return output_file.as<std::string>();
  126. } else {
  127. std::cout << "Must specify output-file in config file." << std::endl;
  128. return "";
  129. }
  130. }
  131. std::vector<DataFileDescriptor> get_source_files() {
  132. std::vector<DataFileDescriptor> source_files;
  133. std::string source_file_key = "source-files";
  134. if (root["source-file-key"]) {
  135. source_file_key = root["source-file-key"].as<std::string>();
  136. }
  137. YAML::Node source_files_nd = root[source_file_key];
  138. if (source_files_nd.IsSequence()) {
  139. for (const auto &f : source_files_nd) {
  140. source_files.push_back(f.as<DataFileDescriptor>());
  141. }
  142. } else {
  143. std::cout << "source-files missing or not a sequence" << std::endl;
  144. }
  145. return source_files;
  146. }
  147. };
  148. Config *the_config = nullptr;
  149. bool debug_on = false;
  150. void init_config(const std::string &input_filename) {
  151. if (the_config) delete the_config;
  152. the_config = new Config(input_filename);
  153. debug_on = the_config->get_debug();
  154. }
  155. }
  156. #endif // config_hpp