| /** |
| * Copyright © 2018 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 "argument.hpp" |
| |
| #include <algorithm> |
| #include <iostream> |
| #include <iterator> |
| |
| namespace phosphor |
| { |
| namespace network |
| { |
| namespace ncsi |
| { |
| |
| 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" |
| " --help | -h Print this menu.\n" |
| " --index=<device index> | -x <device index> Specify device ifindex.\n" |
| " --package=<package> | -p <package> Specify a package.\n" |
| " --channel=<channel> | -c <channel> Specify a channel.\n" |
| " --info | -i Retrieve info about NCSI topology.\n" |
| " --set | -s Set a specific package/channel.\n" |
| " --clear | -r Clear all the settings on the interface.\n" |
| " --oem-payload=<hex data...> | -o <hex data...> Send an OEM command with payload.\n" |
| "\n" |
| "Example commands:\n" |
| " 1) Retrieve topology information:\n" |
| " ncsi-netlink -x 3 -p 0 -i\n" |
| " 2) Set preferred package\n" |
| " ncsi-netlink -x 3 -p 0 -s\n" |
| " 3) Set preferred channel\n" |
| " ncsi-netlink -x 3 -p 0 -c 1 -s\n" |
| " 4) Clear preferred channel\n" |
| " ncsi-netlink -x 3 -p 0 -r\n" |
| " 5) Send NCSI Command\n" |
| " ncsi-netlink -x 3 -p 0 -c 0 -o 50000001572100\n" |
| "\n"; |
| } |
| |
| const option ArgumentParser::options[] = { |
| {"info", no_argument, NULL, 'i'}, |
| {"set", no_argument, NULL, 's'}, |
| {"clear", no_argument, NULL, 'r'}, |
| {"oem-payload", required_argument, NULL, 'o'}, |
| {"package", required_argument, NULL, 'p'}, |
| {"channel", required_argument, NULL, 'c'}, |
| {"index", required_argument, NULL, 'x'}, |
| {"help", no_argument, NULL, 'h'}, |
| {0, 0, 0, 0}, |
| }; |
| |
| const char* ArgumentParser::optionStr = "irsx:o:p:c:h?"; |
| |
| const std::string ArgumentParser::trueString = "true"; |
| const std::string ArgumentParser::emptyString = ""; |
| |
| } // namespace ncsi |
| } // namespace network |
| } // namespace phosphor |