/** * 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 #include #include #include "argument.hpp" namespace phosphor { namespace gpio { using namespace std::string_literals; const std::string ArgumentParser::trueString = "true"s; const std::string ArgumentParser::emptyString = ""s; const char* ArgumentParser::optionStr = "p:k:n:i:d:?h"; const option ArgumentParser::options[] = { { "path", required_argument, nullptr, 'p' }, { "key", required_argument, nullptr, 'k' }, { "name", required_argument, nullptr, 'n' }, { "inventory", required_argument, nullptr, 'i' }, { "drivers", required_argument, nullptr, 'd' }, { "help", no_argument, nullptr, 'h' }, { 0, 0, 0, 0}, }; ArgumentParser::ArgumentParser(int argc, char** argv) { auto option = 0; while (-1 != (option = getopt_long(argc, argv, optionStr, options, nullptr))) { 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 << " --inventory= Object path under inventory" " that will be created\n"; std::cerr << " --path= Path of device to read for GPIO pin" " state to determine presence of inventory item\n"; std::cerr << " --key= Input GPIO key number\n"; std::cerr << " --name= Pretty name of the inventory" " item\n"; std::cerr << " --drivers= List of drivers to bind when card" " is added and unbind when card is removed\n"; std::cerr << " Format is a space separated list" " of path,device pairs. For example:\n"; std::cerr << " " "/sys/bus/i2c/drivers/some-driver,3-0068\n"; std::cerr << std::flush; exit(-1); } } // namespace gpio } // namespace phosphor