| /* |
| * |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| * |
| */ |
| |
| #include "./qpidd.h" |
| #include "qpid/Plugin.h" |
| #include "qpid/Version.h" |
| #include "qpid/log/Logger.h" |
| #include "qpid/log/Statement.h" |
| |
| #include <iostream> |
| #include <memory> |
| using namespace std; |
| |
| auto_ptr<QpiddOptions> options; |
| |
| int main(int argc, char* argv[]) |
| { |
| try |
| { |
| BootstrapOptions bootOptions(argv[0]); |
| string defaultPath (bootOptions.module.loadDir); |
| // Parse only the common, load, and log options to see which |
| // modules need to be loaded. Once the modules are loaded, |
| // the command line will be re-parsed with all of the |
| // module-supplied options. |
| try { |
| bootOptions.parse (argc, argv, bootOptions.common.config, true); |
| qpid::log::Logger::instance().configure(bootOptions.log); |
| } catch (const std::exception& e) { |
| // Couldn't configure logging so write the message direct to stderr. |
| cerr << "Unexpected error: " << e.what() << endl; |
| return 1; |
| } |
| |
| for (vector<string>::iterator iter = bootOptions.module.load.begin(); |
| iter != bootOptions.module.load.end(); |
| iter++) |
| qpid::tryShlib (iter->data(), false); |
| |
| if (!bootOptions.module.noLoad) { |
| bool isDefault = defaultPath == bootOptions.module.loadDir; |
| qpid::loadModuleDir (bootOptions.module.loadDir, isDefault); |
| } |
| |
| // Parse options |
| options.reset(new QpiddOptions(argv[0])); |
| options->parse(argc, argv, options->common.config); |
| |
| // Options that just print information. |
| if (options->common.help || options->common.version) { |
| if (options->common.version) |
| cout << "qpidd (" << qpid::product << ") version " |
| << qpid::version << endl; |
| else if (options->common.help) |
| options->usage(); |
| return 0; |
| } |
| |
| // Everything else is driven by the platform-specific broker |
| // logic. |
| QpiddBroker broker; |
| return broker.execute(options.get()); |
| } |
| catch(const exception& e) { |
| QPID_LOG(critical, "Unexpected error: " << e.what()); |
| } |
| return 1; |
| } |