summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authormidipix <writeonce@midipix.org>2016-03-15 13:33:03 -0400
committermidipix <writeonce@midipix.org>2016-11-10 23:35:40 -0500
commit35bbe74272e8a4e0e4bbc2398107ce5228c5b381 (patch)
tree9d40c21f766230d61d7c2cc8de5dea0811b684ad /src
parent9b44da0730710a0b6ebe4277cd59e8d7ee7044be (diff)
downloadperk-35bbe74272e8a4e0e4bbc2398107ce5228c5b381.tar.bz2
perk-35bbe74272e8a4e0e4bbc2398107ce5228c5b381.tar.xz
argv.h: usage screen generator: fix typesetting of spanning paradigms.
Diffstat (limited to 'src')
-rw-r--r--src/internal/argv/argv.h31
1 files changed, 25 insertions, 6 deletions
diff --git a/src/internal/argv/argv.h b/src/internal/argv/argv.h
index cf24c56..90961b8 100644
--- a/src/internal/argv/argv.h
+++ b/src/internal/argv/argv.h
@@ -910,6 +910,9 @@ static void argv_usage(
}
}
+ para = 0;
+ next_para = 0;
+
if (option->argname) {
if (option->optarg == ARGV_OPTARG_OPTIONAL)
fprintf(file,"[%s]%-*c",
@@ -919,7 +922,6 @@ static void argv_usage(
fprintf(file,"%s%-*c",
option->argname,
(int)(paralen-strlen(option->argname)),' ');
- para = (char *)0;
} else if (option->paradigm && (rparalen <= paralen)) {
if (option->optarg == ARGV_OPTARG_OPTIONAL)
fprintf(file,"[{%s}]%-*c",
@@ -929,7 +931,6 @@ static void argv_usage(
fprintf(file,"{%s}%-*c",
option->paradigm,
(int)(paralen-strlen(option->paradigm)-rbblen),' ');
- para = (char *)0;
} else if (option->paradigm) {
if (!paradigm && !(paradigm = calloc(1,mparalen))) {
fputc('\n',file);
@@ -944,10 +945,8 @@ static void argv_usage(
fputc('{',file);
rparalen = paralen - rblen;
}
- } else {
+ } else
fprintf(file,"%-*c",(int)paralen,' ');
- para = (char *)0;
- }
if (!para && option->description && rdesclen <= desclen) {
@@ -960,6 +959,24 @@ static void argv_usage(
desc = (char *)0;
while (para || desc) {
+ if (para && next_para) {
+ if (option->optarg == ARGV_OPTARG_OPTIONAL) {
+ if (rparalen+2*rbblen <= paralen) {
+ fprintf(file," %s}]%-*c",para,
+ (int)(paralen-rparalen)
+ - 2*rbblen,' ');
+ para = (char *)0;
+ }
+ } else {
+ if (rparalen+2*rblen <= paralen) {
+ fprintf(file," %s}%-*c",para,
+ (int)(paralen-rparalen)
+ - 2*rblen,' ');
+ para = (char *)0;
+ }
+ }
+ }
+
if (para) {
next_para = para+rparalen-1;
@@ -1001,7 +1018,9 @@ static void argv_usage(
(int)(paralen-strlen(para)-rblen),' ');
para = (char *)0;
}
- } else if (desc > buf)
+ } else if (next_para && (desc > buf))
+ next_para = (char *)0;
+ else if (desc > buf)
fprintf(file,"%-*c",(int)paralen,' ');
if (desc) {