config-file.hpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2013-2024 Regents of the University of California.
4  *
5  * This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
6  *
7  * ndn-cxx library is free software: you can redistribute it and/or modify it under the
8  * terms of the GNU Lesser General Public License as published by the Free Software
9  * Foundation, either version 3 of the License, or (at your option) any later version.
10  *
11  * ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
12  * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13  * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
14  *
15  * You should have received copies of the GNU General Public License and GNU Lesser
16  * General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
17  * <http://www.gnu.org/licenses/>.
18  *
19  * See AUTHORS.md for complete list of ndn-cxx authors and contributors.
20  */
21 
22 #ifndef NDN_CXX_MANAGEMENT_CONFIG_FILE_HPP
23 #define NDN_CXX_MANAGEMENT_CONFIG_FILE_HPP
24 
26 
27 #include <filesystem>
28 #include <fstream>
29 
30 #include <boost/property_tree/ptree.hpp>
31 
32 namespace ndn {
33 
48 class ConfigFile : noncopyable
49 {
50 public:
51  class Error : public std::runtime_error
52  {
53  public:
54  using std::runtime_error::runtime_error;
55  };
56 
57  using Parsed = boost::property_tree::ptree;
58 
64  ConfigFile();
65 
66  ~ConfigFile();
67 
68  const std::filesystem::path&
69  getPath() const noexcept
70  {
71  return m_path;
72  }
73 
74  const Parsed&
75  getParsedConfiguration() const noexcept
76  {
77  return m_config;
78  }
79 
80 private:
81  bool
82  open();
83 
84  void
85  close();
86 
97  const Parsed&
98  parse();
99 
111  std::filesystem::path
112  findConfigFile();
113 
114 private:
115  std::filesystem::path m_path; // absolute path to active configuration file (if any)
116  std::ifstream m_input;
117  Parsed m_config;
118 };
119 
120 } // namespace ndn
121 
122 #endif // NDN_CXX_MANAGEMENT_CONFIG_FILE_HPP
System configuration file for NDN platform.
Definition: config-file.hpp:49
ConfigFile()
Locate, open, and parse a library configuration file.
Definition: config-file.cpp:29
const Parsed & getParsedConfiguration() const noexcept
Definition: config-file.hpp:75
const std::filesystem::path & getPath() const noexcept
Definition: config-file.hpp:69
boost::property_tree::ptree Parsed
Definition: config-file.hpp:57
Common includes and macros used throughout the library.
Definition: data.cpp:25