blob: 6ce292a08863927ef541192f15c262c5c715350a [file] [log] [blame]
Chengyu Fanb25835b2015-04-28 17:09:35 -06001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2014 Regents of the University of California,
4 * Arizona Board of Regents,
5 * Colorado State University,
6 * University Pierre & Marie Curie, Sorbonne University,
7 * Washington University in St. Louis,
8 * Beijing Institute of Technology
9 *
10 * This file is part of NFD (Named Data Networking Forwarding Daemon).
11 * See AUTHORS.md for complete list of NFD authors and contributors.
12 *
13 * NFD is free software: you can redistribute it and/or modify it under the terms
14 * of the GNU General Public License as published by the Free Software Foundation,
15 * either version 3 of the License, or (at your option) any later version.
16 *
17 * NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
18 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
19 * PURPOSE. See the GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License along with
22 * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
23 **/
24
25#ifndef ATMOS_CATALOG_CONFIG_FILE_HPP
26#define ATMOS_CATALOG_CONFIG_FILE_HPP
27
28#include <boost/property_tree/ptree.hpp>
29#include <map>
30
31namespace atmos {
32namespace util{
33
34typedef boost::property_tree::ptree ConfigSection;
35
36/// \brief callback for config file sections
37typedef std::function<void(const ConfigSection& /*section*/,
38 bool /*isDryRun*/,
39 const std::string& /*filename*/)> ConfigSectionHandler;
40
41/// \brief callback for config file sections without a subscribed handler
42typedef std::function<void(const std::string& /*filename*/,
43 const std::string& /*sectionName*/,
44 const ConfigSection& /*section*/,
45 bool /*isDryRun*/)> UnknownConfigSectionHandler;
46
47class ConfigFile : boost::noncopyable
48{
49public:
50
51 class Error : public std::runtime_error
52 {
53 public:
54 explicit
55 Error(const std::string& what)
56 : std::runtime_error(what)
57 {
58
59 }
60 };
61
62 ConfigFile(UnknownConfigSectionHandler unknownSectionCallback = throwErrorOnUnknownSection);
63
64 static void
65 throwErrorOnUnknownSection(const std::string& filename,
66 const std::string& sectionName,
67 const ConfigSection& section,
68 bool isDryRun);
69
70 static void
71 ignoreUnknownSection(const std::string& filename,
72 const std::string& sectionName,
73 const ConfigSection& section,
74 bool isDryRun);
75
76 /// \brief setup notification of configuration file sections
77 void
78 addSectionHandler(const std::string& sectionName,
79 ConfigSectionHandler subscriber);
80
81
82 /**
83 * \param filename file to parse
84 * \param isDryRun true if performing a dry run of configuration, false otherwise
85 * \throws ConfigFile::Error if file not found
86 * \throws ConfigFile::Error if parse error
87 */
88 void
89 parse(const std::string& filename, bool isDryRun);
90
91 /**
92 * \param input configuration (as a string) to parse
93 * \param isDryRun true if performing a dry run of configuration, false otherwise
94 * \param filename optional convenience argument to provide more detailed error messages
95 * \throws ConfigFile::Error if file not found
96 * \throws ConfigFile::Error if parse error
97 */
98 void
99 parse(const std::string& input, bool isDryRun, const std::string& filename);
100
101 /**
102 * \param input stream to parse
103 * \param isDryRun true if performing a dry run of configuration, false otherwise
104 * \param filename optional convenience argument to provide more detailed error messages
105 * \throws ConfigFile::Error if parse error
106 */
107 void
108 parse(std::istream& input, bool isDryRun, const std::string& filename);
109
110private:
111
112 void
113 process(bool isDryRun, const std::string& filename);
114
115private:
116 UnknownConfigSectionHandler m_unknownSectionCallback;
117
118 typedef std::map<std::string, ConfigSectionHandler> SubscriptionTable;
119
120 SubscriptionTable m_subscriptions;
121
122 ConfigSection m_global;
123};
124} // namespace util
125} // namespace atmos
126
127
128#endif // ATMOS_CATALOG_CONFIG_FILE_HPP