《commander-cpp》单头文件的、链式调用的、自动生成帮助文档的C++命令行参数解析库

《commander-cpp》单头文件的、链式调用的、自动生成帮助文档的C++命令行参数解析库

前言

作者我本人经常会写一些命令行小工具,

此前一直使用node.js的三方库commander.js来解析命令行参数,

commander.js是一个非常方便的命令行参数解析库,

但是使用node.js也会有一些限制,比如:运行的电脑上需要安装node.js,并且在一些对性能要求比较高的场景就会不太方便了,

针对上述情况,我尝试切换到c++,但是在实际写代码时发现,现有的命令行解析库使用时没有commander.js那么丝滑,让我很难受,

于是,我决定仿照commander.js的设计,写一个c++的命令行参数解析库,取名为commander-cpp,头文件名为commander_cpp.hpp

仓库

仓库地址:https://github.com/DoYoungDo/commander-cpp

特性

  • 🎯 链式 API 设计,简洁易用
  • 📦 单头文件,无外部依赖
  • 🔧 支持选项(单值、多值、布尔值)
  • 📝 支持参数(必需参数、可选参数、多值参数)
  • 🌲 支持子命令和嵌套命令
  • ⚙️ 支持默认值
  • 📖 自动生成帮助信息
  • 🔍 详细的错误处理和日志系统
  • 🎨 支持选项别名和组合(如 -abc

安装

commander_cpp.hpp 文件复制到项目中,并在代码中包含它:

cpp 复制代码
#include "commander_cpp.hpp"

示例

示例代码

cpp 复制代码
#include "commander_cpp.hpp"
using namespace COMMANDER_CPP;

int main(int argc, char **argv) {
    // 构造一个Command对象,命令名为"example", 等价于:Command().name("example")
    Command("example")
        // 设置版本号
        .version("1.0.0")
        // 添加一个简介描述文本
        ->description("一个示例命令行应用")
        // 添加一个选项,选项名是'name',设置别名'n',并指定参数必选
        ->option("-n --name <name>", "你的名字" /* 选项的描述 */)
        // 添加一个参数,参数名是'file',并指定参数可选
        ->argument("[file]", "要处理的文件路径")
        // 添加一个动作回调,当命令行参数解析完成后调用
        ->action([](Vector<Variant/* = std::variant<...> */> args /* 参数值列表 */, Map<String /* 选项名 */, Variant /* 选项值 */> opts /* 选项值列表 */) {
            if (opts.find("name") != opts.end()) {
                std::cout << "Hello, " << std::get<String>(opts["name"]) << "!" << std::endl;
            } else {
                std::cout << "Hello, World!" << std::endl;
            }
        })
        // 解析命令行参数
        ->parse(argc, argv);
    return 0;
}

运行示例

bash 复制代码
$ ./example -n Alice
Hello, Alice!

$ ./example -V
1.0.0

$ ./example --help
Usage: example [options]

一个示例命令行应用

Options:
  -V, --version       out put version number.
  -n, --name <name>   你的名字
  -h, --help

更多示例...

注意

  • 支持 C++17 或更高版本
相关推荐
vegetablesssss5 小时前
=和{}赋值区别
c++
dyyx1115 小时前
C++编译期数据结构
开发语言·c++·算法
曼巴UE55 小时前
UE C++ 组件 非构造函数创建的技巧
开发语言·c++
2301_790300965 小时前
C++中的观察者模式实战
开发语言·c++·算法
坐怀不乱杯魂5 小时前
Linux - 线程的同步与互斥
linux·c++
HABuo5 小时前
【linux基础I/O(一)】文件系统调用接口&文件描述符详谈
linux·运维·服务器·c语言·c++·ubuntu·centos
2401_891450465 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
小y要自律6 小时前
08 string容器 - 字符串比较
开发语言·c++·stl
历程里程碑6 小时前
双指针--双数之和
开发语言·数据结构·c++·算法·排序算法·哈希算法·散列表
yanlou2336 小时前
【C++/Linux实战项目】仿muduo库实现高性能Reactor模式TCP服务器(深度解析)
linux·服务器·c++·tcp/ip·epoll