《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 或更高版本
相关推荐
晚风叙码2 小时前
《C++面向对象进阶:static成员、友元、匿名对象与拷贝优化详解》
c++
j7~2 小时前
【C++】STL--string类--拆析解剖string以及string类的底层详解(1)
开发语言·c++·ascii编码·string类·auto和范围for
草莓熊Lotso2 小时前
【Linux网络】深入理解 TCP 协议(二):序号机制、流量控制与连接管理
linux·运维·服务器·网络·c++·tcp/ip
小欣加油13 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
星恒随风14 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
浪客灿心14 小时前
项目篇:模块设计与实现
数据库·c++
牛油果子哥q14 小时前
【C++ STL vector】C++ STL vector 终极精讲:动态数组底层原理、两倍扩容机制、迭代器失效、增删查改、性能剖析与工程避坑指南
开发语言·c++
为何创造硅基生物16 小时前
独占指针的创建std::make_unique 本身自带堆出现
c++
kyle~16 小时前
ROS 2 与 Isaac Sim 联合仿真(一)体系架构、环境选型与基础通信闭环
c++·机器人·nvidia·仿真·ros2
努力努力再努力wz17 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表