added support for --flags
This commit is contained in:
parent
7266746727
commit
cb953cc3f2
51
carg-parse.c
51
carg-parse.c
@ -14,26 +14,38 @@ carg_parse_data* carg_parse(int argc, char** argv)
|
|||||||
char **lv_values = (char**)malloc(sizeof(char*) * argc);
|
char **lv_values = (char**)malloc(sizeof(char*) * argc);
|
||||||
uint32_t lv_cp = 0;
|
uint32_t lv_cp = 0;
|
||||||
|
|
||||||
|
char **flags = (char**)malloc(sizeof(char*) * argc);
|
||||||
|
uint32_t flags_cp = 0;
|
||||||
|
|
||||||
data->exec_name = argv[0];
|
data->exec_name = argv[0];
|
||||||
|
|
||||||
for (int i = 1; i < argc; i++)
|
for (int i = 1; i < argc; i++)
|
||||||
{
|
{
|
||||||
if (argv[i][0] == '-') // label
|
if (argv[i][0] == '-') // label / flag
|
||||||
{
|
{
|
||||||
lv_labels[lv_cp] = argv[i] + 1;
|
if (argv[i][1] != '\0' && argv[i][1] == '-') // flag
|
||||||
|
{
|
||||||
|
flags[flags_cp] = argv[i] + 2;
|
||||||
|
|
||||||
if (argc > i + 1 && argv[i + 1][0] != '-')
|
flags_cp++;
|
||||||
{
|
}
|
||||||
i++;
|
else // label
|
||||||
|
{
|
||||||
|
lv_labels[lv_cp] = argv[i] + 1;
|
||||||
|
|
||||||
lv_values[lv_cp] = argv[i];
|
if (argc > i + 1 && argv[i + 1][0] != '-')
|
||||||
}
|
{
|
||||||
else
|
i++;
|
||||||
{
|
|
||||||
lv_values[lv_cp] = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
lv_cp++;
|
lv_values[lv_cp] = argv[i];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
lv_values[lv_cp] = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
lv_cp++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else // not labelled
|
else // not labelled
|
||||||
{
|
{
|
||||||
@ -65,6 +77,16 @@ carg_parse_data* carg_parse(int argc, char** argv)
|
|||||||
data->lv_values = NULL;
|
data->lv_values = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
data->flags_len = flags_cp;
|
||||||
|
if (flags_cp > 0)
|
||||||
|
{
|
||||||
|
data->flags = realloc(flags, sizeof(char*) * flags_cp);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
data->flags = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -84,5 +106,10 @@ void carg_parse_free(carg_parse_data* data)
|
|||||||
free(data->lv_values);
|
free(data->lv_values);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (data->flags != NULL)
|
||||||
|
{
|
||||||
|
free(data->flags);
|
||||||
|
}
|
||||||
|
|
||||||
free(data);
|
free(data);
|
||||||
}
|
}
|
@ -15,6 +15,9 @@ typedef struct
|
|||||||
uint32_t lv_len;
|
uint32_t lv_len;
|
||||||
char** lv_labels;
|
char** lv_labels;
|
||||||
char** lv_values;
|
char** lv_values;
|
||||||
|
|
||||||
|
uint32_t flags_len;
|
||||||
|
char** flags;
|
||||||
} carg_parse_data;
|
} carg_parse_data;
|
||||||
|
|
||||||
carg_parse_data* carg_parse(int argc, char** argv);
|
carg_parse_data* carg_parse(int argc, char** argv);
|
||||||
|
Loading…
Reference in New Issue
Block a user