diff options
Diffstat (limited to 'host')
| -rw-r--r-- | host/lib/cal/database.cpp | 65 | 
1 files changed, 41 insertions, 24 deletions
| diff --git a/host/lib/cal/database.cpp b/host/lib/cal/database.cpp index 16fcd4b71..fde55e8ba 100644 --- a/host/lib/cal/database.cpp +++ b/host/lib/cal/database.cpp @@ -12,6 +12,9 @@  #include <boost/filesystem.hpp>  #include <ctime>  #include <fstream> +#include <array> +#include <tuple> +#include <vector>  CMRC_DECLARE(rc); @@ -29,22 +32,24 @@ constexpr char CAL_EXT[]          = ".cal";  // we first load it entirely into heap space, and then deserialize it from there.  constexpr size_t CALDATA_MAX_SIZE = 10 * 1024 * 1024; // 10 MiB - -//! Map a cal resource key into a source::RC path name +/****************************************************************************** + * RC implementation + *****************************************************************************/ +//! Helper: Map a cal resource key into a source::RC path name  std::string get_cal_path_rc(const std::string& key)  {      return std::string("cal/") + key + CAL_EXT;  }  //! Return true if a cal data resource with given key exists -bool has_cal_data_rc(const std::string& key) +bool has_cal_data_rc(const std::string& key, const std::string&)  {      auto fs = rc::get_filesystem();      return fs.is_file(get_cal_path_rc(key));  }  //! Return a byte array for a given cal resource -std::vector<uint8_t> get_cal_data_rc(const std::string& key) +std::vector<uint8_t> get_cal_data_rc(const std::string& key, const std::string&)  {      try {          auto fs   = rc::get_filesystem(); @@ -55,6 +60,11 @@ std::vector<uint8_t> get_cal_data_rc(const std::string& key)      }  } +/****************************************************************************** + * Filesystem implementation + *****************************************************************************/ +//! Helper: Check a path exists, or create it if not. Does not create recursively, +// think mkdir, not mkdir -p.  void check_or_create_dir(fs::path dir)  {      if (fs::exists(dir)) { @@ -95,8 +105,8 @@ void assert_cal_dir_exists()      check_or_create_dir(cal_path);  } - -//! Map a cal resource key into a filesystem path name (relative to get_cal_data_path()) +//! Helper: Map a cal resource key into a filesystem path name +// (relative to get_cal_data_path())  std::string get_cal_path_fs(const std::string& key, const std::string& serial)  {      return key + "_" + serial + CAL_EXT; @@ -139,18 +149,29 @@ std::vector<uint8_t> get_cal_data_fs(const std::string& key, const std::string&  } // namespace + +/****************************************************************************** + * Function lookup + *****************************************************************************/ +typedef bool (*has_cal_data_fn)(const std::string&, const std::string&); +typedef std::vector<uint8_t> (*get_cal_data_fn)(const std::string&, const std::string&); +// These are in order of priority! +constexpr std::array<std::tuple<source, has_cal_data_fn, get_cal_data_fn>, 2> data_fns{ +    {{source::FILESYSTEM, &has_cal_data_fs, &get_cal_data_fs}, +        {source::RC, &has_cal_data_rc, &get_cal_data_rc}}}; + + +/****************************************************************************** + * cal::database implementation + *****************************************************************************/  std::vector<uint8_t> database::read_cal_data(      const std::string& key, const std::string& serial, const source source_type)  { -    if (source_type == source::FILESYSTEM || source_type == source::ANY) { -        if (has_cal_data_fs(key, serial)) { -            return get_cal_data_fs(key, serial); -        } -    } - -    if (source_type == source::RC || source_type == source::ANY) { -        if (has_cal_data_rc(key)) { -            return get_cal_data_rc(key); +    for (auto& data_fn : data_fns) { +        if (source_type == source::ANY || source_type == std::get<0>(data_fn)) { +            if (std::get<1>(data_fn)(key, serial)) { +                return std::get<2>(data_fn)(key, serial); +            }          }      } @@ -163,15 +184,11 @@ std::vector<uint8_t> database::read_cal_data(  bool database::has_cal_data(      const std::string& key, const std::string& serial, const source source_type)  { -    if (source_type == source::FILESYSTEM || source_type == source::ANY) { -        if (has_cal_data_fs(key, serial)) { -            return true; -        } -    } - -    if (source_type == source::RC || source_type == source::ANY) { -        if (has_cal_data_rc(key)) { -            return true; +    for (auto& data_fn : data_fns) { +        if (source_type == source::ANY || source_type == std::get<0>(data_fn)) { +            if (std::get<1>(data_fn)(key, serial)) { +                return true; +            }          }      } | 
