diff options
author | Alan Conway <aconway@apache.org> | 2007-04-26 16:21:23 +0000 |
---|---|---|
committer | Alan Conway <aconway@apache.org> | 2007-04-26 16:21:23 +0000 |
commit | b418805cf2a2e1ac5336b0cd6335c4400c12e1c6 (patch) | |
tree | b0e272b825fa7e2c0700e8f818cc84f6d461992c /cpp/src | |
parent | 0a90e5db613b035e15af3b7358205ed1f7960d2c (diff) | |
download | qpid-python-b418805cf2a2e1ac5336b0cd6335c4400c12e1c6.tar.gz |
Merged revisions 532430 by hand from
https://svn.apache.org/repos/asf/incubator/qpid/branches/trunk/qpid/cpp
------------------------------------------------------------------------
r532750 | aconway | 2007-04-26 10:13:14 -0400 (Thu, 26 Apr 2007) | 4 lines
- docs/man/qpidd.x: explain file and environment configuration.
- src/qpidd.cpp: read config from file.
------------------------------------------------------------------------
r532491 | aconway | 2007-04-25 17:26:53 -0400 (Wed, 25 Apr 2007) | 4 lines
Added environment variables as a source of Qpid configuration.
Option "foo-bar" will be read from env. QPID_FOO_BAR if
not specified on command line.
------------------------------------------------------------------------
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/branches/M2@532791 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src')
-rw-r--r-- | cpp/src/qpidd.cpp | 31 |
1 files changed, 25 insertions, 6 deletions
diff --git a/cpp/src/qpidd.cpp b/cpp/src/qpidd.cpp index 532636602e..ec8fe570d3 100644 --- a/cpp/src/qpidd.cpp +++ b/cpp/src/qpidd.cpp @@ -24,7 +24,7 @@ #include <memory> #include <config.h> #include <unistd.h> - +#include <fstream> using namespace qpid; using namespace qpid::broker; @@ -37,34 +37,53 @@ struct QpiddOptions : public Broker::Options bool help; bool version; bool daemon; + string config; po::options_description desc; QpiddOptions() : - help(false), version(false), daemon(false), desc("Options") + help(false), version(false), daemon(false), + config("/etc/qpidd.conf"), + desc("Options") { using namespace po; desc.add_options() ("daemon,d", optValue(daemon), "Run as a daemon"); Broker::Options::addTo(desc); desc.add_options() + ("config", optValue(config, "FILE"), "Configuation file") ("help,h", optValue(help), "Print help message") ("version,v", optValue(version), "Print version information"); } void parse(int argc, char* argv[]) { po::variables_map vm; + // Earlier sources get precedence. po::store(po::parse_command_line(argc, argv, desc), vm); + try { + po::store(po::parse_environment(desc, po::env2option), vm); + } + catch (const logic_error& e) { + throw logic_error(string("parsing environment variables: ") + + e.what()); + } + po::notify(vm); // So we can use the value of config. + try { + ifstream conf(config.c_str()); + po::store(po::parse_config_file(conf, desc), vm); + } + catch (const logic_error& e) { + throw logic_error(string("parsing config file: ")+ e.what()); + } po::notify(vm); }; - void usage(std::ostream& out) const { - out << "Usage: qpidd [OPTIONS]" << endl - << "Start the Qpid AMQP broker." << endl << endl + void usage(ostream& out) const { + out << "Usage: qpidd [OPTIONS]" << endl << endl << desc << endl; }; }; -std::ostream& operator<<(std::ostream& out, const QpiddOptions& config) { +ostream& operator<<(ostream& out, const QpiddOptions& config) { config.usage(out); return out; } |