一个C语言命令行解析器

简介: 一个C语言命令行解析器

e4f4eb79d11fd35543c801055ce8ed10_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.png

开源地址:https://github.com/dwpeng/argparse

argparse

C语言命令解析器

🎉文档

定义参数

使用ae_defineArgs(name)来定义参数,其中name为定义的名字,该宏可以产生一个参数ae_arg_t数组。ae_arg_t结构体如下

typedef struct
{
    /* 单短线参数名 */
    char* short_arg;
    /* 双短线参数名 */
    char* long_arg;
    /* 是否跟随参数值 */
    ArgValue arg_have_value;
    /* 传递值 */
    char* value;
    /* 初始值 */
    union {
        int i;
        bool b;
        float f;
        char* s;
        void* v;
    } init;
    /* 参数的说明 */
    char* help;
} ae_arg_t;
typedef enum {
    AE_YES = 0,
    AE_NO
} ArgValue;

参数分为需要跟随参数值和不跟随参数值两种,需要通过arg_have_value进行设置,为AE_YES即为需要参数值,AE_NO为不需要参数值,在不设置的情况下,默认需要参数值。

通过init设置初始值,支持多种类型,当参数的arg_have_valueAE_NO时,参数值将被存储到init.b中。

在定义参数值时,参数数组最后必须传递一个AE_END宏,使其作为数组的最后一个元素。

定义回调函数

通过ae_defineCallback(name)定义回调函数,name为回调函数的名字,该宏可以产生一个函数,函数签名如下

typedef void (*callback_t)(int argc, char* argv[], char* env[]);

获取参数

在回调函数内部使用ae_get来获取参数结构体,函数原型如下

static inline ae_arg_t* ae_get(char* arg_name)

创建解析器

ae_init_parser(char* print_message, print_ae_command_t print_command)

第一个参数为打印信息

第二个参数为如何去打印一个命令中的参数

添加一个命令

static inline void
ae_add_command(
    char* command,      // 子命令名,为NULL时,即为全局命令
    char* description,  // 子命令的描述
    char* usage,        // 子命令的使用方法
    callback_t callback,// 子命令的回调函数
    ae_arg_t* args      // 子命令对应的参数
)

开始解析

static inline void ae_do_parser(int argc, char* argv[], char* env[])

解析函数与一般的main函数的参数相同

  • 第一个参数为 参数个数
  • 第二个参数为 参数值数组
  • 第三个参数为 环境变量数组

使用时,main函数一般使用如下定义

int main(int argc, char* argv[], char* env[])

✨例子

// test.c
#include "argparse-new.h"
// Step1: 定义参数
ae_defineArgs(help_args) = {
    {
        .short_arg = "a",
        .long_arg = "apple",
        .init.s = "default_value"
    },
    {
     .short_arg = "s",
     .long_arg = "sleep",
     .arg_have_value = AE_NO,
     .init.b = 0
    },
    AE_END
};
// Step2: 定义回调函数
ae_defineCallback(help_callback)
{
    ae_arg_t* arg = ae_get("apple");
    if (!arg->value) {
        printf("no value. init: %s\n", arg->init.s);
    } else {
        printf("%s\n", arg->value);
    }
    printf("%d\n", ae_get("sleep")->init.b);
}
int
main(int argc, char* argv[], char* env[])
{
    // Step3: 初始化解析器
    ae_init_parser("This is a argparse example.", NULL);
    // Step4: 添加命令
    ae_add_command("help", "This is description.", "This is usage.", help_callback, help_args);
    ae_add_command("testhelp", "This is description.", "This is usage.", help_callback, help_args);
    // Step5: 开始解析
    ae_do_parser(argc, argv, env);
}


相关文章
|
2天前
|
C语言
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
|
2天前
|
编译器 C语言
操作符详解(C语言基础深入解析)
操作符详解(C语言基础深入解析)
|
2天前
|
存储 程序员 C语言
【C 言专栏】C 语言指针的深度解析
【4月更文挑战第30天】C 语言中的指针是程序设计的关键,它如同一把钥匙,提供直接内存操作的途径。指针是存储其他变量地址的变量,通过声明如`int *ptr`来使用。它们在动态内存分配、函数参数传递及数组操作中发挥重要作用。然而,误用指针可能导致错误,如空指针引用和内存泄漏。理解指针的运算、与数组和函数的关系,以及在结构体中的应用,是成为熟练 C 语言程序员的必经之路。虽然挑战重重,但掌握指针将增强编程效率和灵活性。不断实践和学习,我们将驾驭指针,探索更广阔的编程世界。
|
2天前
|
存储 C语言
指针深入解析(C语言基础)带你走进指针,了解指针
指针深入解析(C语言基础)带你走进指针,了解指针
|
2天前
|
存储 编译器 C语言
C语言基础知识:数据在内存中的存储解析(整数,浮点数)
C语言基础知识:数据在内存中的存储解析(整数,浮点数)
|
2天前
|
C语言 C++
C语言:指针运算笔试题解析(包括令人费解的指针题目)
C语言:指针运算笔试题解析(包括令人费解的指针题目)
|
2天前
|
机器学习/深度学习 C语言
函数递归深入解析(C语言)
函数递归深入解析(C语言)
|
2天前
|
编译器 C语言
函数深入解析(C语言基础入门)
函数深入解析(C语言基础入门)
|
2天前
|
C语言
循坏语句解析(C语言零基础教程)
循坏语句解析(C语言零基础教程)
|
1天前
HuggingFace Tranformers 源码解析(4)
HuggingFace Tranformers 源码解析
5 0

推荐镜像

更多