summaryrefslogtreecommitdiff
path: root/cpp/src
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2007-04-26 16:21:23 +0000
committerAlan Conway <aconway@apache.org>2007-04-26 16:21:23 +0000
commitb418805cf2a2e1ac5336b0cd6335c4400c12e1c6 (patch)
treeb0e272b825fa7e2c0700e8f818cc84f6d461992c /cpp/src
parent0a90e5db613b035e15af3b7358205ed1f7960d2c (diff)
downloadqpid-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.cpp31
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;
}