4

我正在编写一个控制台应用程序,它正在迅速获得许多命令行参数和标志。出于这个原因,我希望用户能够访问这些标志的描述以及它们的用途。

我能想到几种可能的解决方案

  • 我可以编写一个 README 文件并将其粘贴在与可执行文件相同的目录中。优点是简单且可移植,但缺点是有人很容易删除/编辑文件。
  • 我可以将整个消息粘贴在程序中的一个变量中,并在用户键入mycmd --help或类似内容时将其打印到屏幕上。优点,保留可执行且不可编辑,缺点在于代码,因为我会在下面浮动类似的东西。

    const char[] helpmsg = "Line1\n"
                           "Line2\n"
                           "...\n"
                           "LineN\n";
    
  • 我可以为我的程序编写一个man条目,但这不是很便携,因为该应用程序在 Windows 和 Linux 上的使用几乎相同。

我知道这个问题可能是一个品味问题,但我只是好奇是否还有其他我没有想到的人们过去使用过的解决方案。

理想情况下,这对开发人员(目前是我)来说很容易编辑和保持更新,但其他人无法真正搞砸它。

4

4 回答 4

8

考虑使用boost 程序选项库。

于 2011-08-26T09:12:14.290 回答
6

要打印帮助消息,我通常为此使用一个函数。因此,您可以在启动时或运行时使用它。例如:

void usage(char* progName)
{
  cout << progName << "[options]" << endl <<
      "Options:" << endl <<
      "-h | --help        Print this help" << endl <<
      "-v | --version     Print the SVN version" << endl <<
      "-V | --Version     Print the proxy version" << endl <<
      "-d | --daemonize   Run as daemon" << endl <<
      "-P | --pidfile     Path to PID file (default: " <<
        WPASUP_PROXY_DEFAULT_PID_FILE << ")" << endl <<
      "-l | --logging     Path to logging file (default: " <<
        WPASUP_PROXY_DEFAULT_LOGGING << ")" << endl <<
      "-i | --ip          The IP address of the main application (default: " <<
        WPASUP_PROXY_MAIN_APP_IP << ")" << endl <<
      "-p | --port        The port number of the main application (default: " <<
        WPASUP_PROXY_DEFAULT_MAIN_APP_PORT << ")" << endl <<
      "-w | --wpa_cli     Path to wpa_cli program (default: " <<
        WPASUP_PROXY_DEFAULT_WPA_CLI << ")" << endl;
}

如果您愿意,您也可以使用 printf 函数......我认为这是一种常见的做法,但如果有人有更好的想法,我会很感兴趣!

问候!

于 2011-08-26T09:12:58.827 回答
1

您也可以编写一个 README 并将prog --help其打印到控制台。

于 2011-08-26T09:30:29.850 回答
0

您可以使用getopt C 库,其目标正是允许解析和使用多个选项(短格式或长格式)。

(注意还有一个getopts程序可以与具有类似功能的 shell 脚本一起使用)

于 2011-08-26T09:26:33.510 回答