blob: a4b664e9586b9cd1a17ba072d3d3dc6dc39f0d2d [file] [log] [blame]
/**
* 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 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=<inventory> Object path under inventory"
" that will be created\n";
std::cerr << " --path=<path> Path of device to read for GPIO pin"
" state to determine presence of inventory item\n";
std::cerr << " --key=<key> Input GPIO key number\n";
std::cerr << " --name=<name> Pretty name of the inventory"
" item\n";
std::cerr << " --drivers=<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