diff options
author | midipix <writeonce@midipix.org> | 2024-06-22 08:55:55 +0000 |
---|---|---|
committer | midipix <writeonce@midipix.org> | 2024-06-22 13:40:13 +0000 |
commit | 58d73004bfe2a10d3488a6c3dac524ac77514363 (patch) | |
tree | 5e3f617ce4cb4a8c72133b9a5fb0efa79f09993a /src/internal/argv | |
parent | aef26f641a87b5395b9d5fcfa25925c6fb07c27c (diff) | |
download | ntux-58d73004bfe2a10d3488a6c3dac524ac77514363.tar.bz2 ntux-58d73004bfe2a10d3488a6c3dac524ac77514363.tar.xz |
argv.h: argv_show_status(): output keyval pairs where appropriate.
Diffstat (limited to 'src/internal/argv')
-rw-r--r-- | src/internal/argv/argv.h | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/src/internal/argv/argv.h b/src/internal/argv/argv.h index 6131485..d287e86 100644 --- a/src/internal/argv/argv.h +++ b/src/internal/argv/argv.h @@ -856,8 +856,10 @@ static void argv_show_status( struct argv_ctx * ctx, struct argv_meta * meta) { + int i; int argc; char ** argv; + struct argv_keyval * keyv; struct argv_entry * entry; const struct argv_option * option; char short_name[2] = {0}; @@ -887,6 +889,27 @@ static void argv_show_status( else argv_dprintf(fd,"[-%s,--%s]\n", short_name,option->long_name); + + if (entry->keyv) { + for (i=0,keyv=entry->keyv; keyv->keyword; i++,keyv++) { + switch (keyv->flags) { + case ARGV_KEYVAL_ASSIGN: + argv_dprintf(fd,"\tkeyval[%d]: <%s>=%s\n", + i,keyv->keyword,keyv->value); + break; + + case ARGV_KEYVAL_OVERRIDE: + argv_dprintf(fd,"\tkeyval[%d]: <%s>:=%s\n", + i,keyv->keyword,keyv->value); + break; + + default: + argv_dprintf(fd,"\tkeyval[%d]: <%s>\n", + i,keyv->keyword); + break; + } + } + } } else { argv_dprintf(fd,"<program arg> := %s\n",entry->arg); } |