| /** |
| * Copyright © 2017 IBM Corporation |
| * |
| * Licensed 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 <iostream> |
| #include <iterator> |
| #include <algorithm> |
| #include "argument.hpp" |
| |
| namespace phosphor |
| { |
| namespace unit |
| { |
| namespace failure |
| { |
| |
| ArgumentParser::ArgumentParser(int argc, char** argv) |
| { |
| int option = 0; |
| while (-1 != (option = getopt_long(argc, argv, optionStr, options, NULL))) |
| { |
| if ((option == '?') || (option == 'h')) |
| { |
| usage(argv); |
| exit(-1); |
| } |
| |
| auto i = &options[0]; |
| while ((i->val != option) && (i->val != 0)) |
| { |
| ++i; |
| } |
| |
| if (i->val) |
| { |
| arguments[i->name] = (i->has_arg ? optarg : trueString); |
| } |
| } |
| } |
| |
| const std::string& ArgumentParser::operator[](const std::string& opt) |
| { |
| auto i = arguments.find(opt); |
| if (i == arguments.end()) |
| { |
| return emptyString; |
| } |
| else |
| { |
| return i->second; |
| } |
| } |
| |
| void ArgumentParser::usage(char** argv) |
| { |
| std::cerr << "Usage: " << argv[0] << " [options]\n"; |
| std::cerr << "Options:\n"; |
| std::cerr << " --help Print this menu\n"; |
| std::cerr << " --source=<source> The source unit to monitor\n"; |
| std::cerr << " --target=<target> The target unit to start or stop\n"; |
| std::cerr << " --action=<action> Target unit action - start or stop\n"; |
| std::cerr << std::flush; |
| } |
| |
| const option ArgumentParser::options[] = |
| { |
| { "source", required_argument, NULL, 's' }, |
| { "action", required_argument, NULL, 'a' }, |
| { "target", required_argument, NULL, 't' }, |
| { "help", no_argument, NULL, 'h' }, |
| { 0, 0, 0, 0}, |
| }; |
| |
| const char* ArgumentParser::optionStr = "s:a:t:h?"; |
| |
| const std::string ArgumentParser::trueString = "true"; |
| const std::string ArgumentParser::emptyString = ""; |
| |
| } |
| } |
| } |