/** * Copyright © 2016 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 #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:r:t:?h"; const option ArgumentParser::options[] = { { "path", required_argument, nullptr, 'p' }, { "key", required_argument, nullptr, 'k' }, { "polarity", required_argument, nullptr, 'r' }, { "target", required_argument, nullptr, 't' }, { "continue", optional_argument, nullptr, 'c' }, { "help", no_argument, nullptr, 'h' }, { 0, 0, 0, 0}, }; ArgumentParser::ArgumentParser(int argc, char** argv) { int 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) { // optinal argument may get nullptr for optarg // make it empty string in such case auto arg = (optarg == nullptr ? "" : optarg); arguments[i->name] = (i->has_arg ? arg : 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 << " --path= Path of input device." " Ex: /dev/input/event2\n"; std::cerr << " --key= Input GPIO key number\n"; std::cerr << " --polarity= Asertion polarity to look for." " This is 0 / 1 \n"; std::cerr << " --target= Systemd unit to be called on GPIO" " state change\n"; std::cerr << " --continue=[true] Whether or not to continue" " after key pressed\n"; } } // namespace gpio } // namespace phosphor