Do not use C99 printf format specifiers and asprintf
This commit is contained in:
114
Str.c
114
Str.c
@@ -427,27 +427,103 @@ Stralign_center(Str s, int width)
|
|||||||
Str
|
Str
|
||||||
Sprintf(char *fmt, ...)
|
Sprintf(char *fmt, ...)
|
||||||
{
|
{
|
||||||
Str s;
|
int len = 0;
|
||||||
char *cb;
|
int status = SP_NORMAL;
|
||||||
int ret;
|
int p = 0;
|
||||||
size_t n;
|
char *f;
|
||||||
va_list ap;
|
Str s;
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
va_start(ap, fmt);
|
va_start(ap, fmt);
|
||||||
ret = vasprintf(&cb, fmt, ap);
|
for (f = fmt; *f; f++) {
|
||||||
if (ret == -1) {
|
redo:
|
||||||
fprintf(stderr,
|
switch (status) {
|
||||||
"Sprintf: vasprintf failed\n");
|
case SP_NORMAL:
|
||||||
exit(1);
|
if (*f == '%') {
|
||||||
|
status = SP_PREC;
|
||||||
|
p = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
len++;
|
||||||
|
break;
|
||||||
|
case SP_PREC:
|
||||||
|
if (IS_ALPHA(*f)) {
|
||||||
|
/* conversion char. */
|
||||||
|
double vd;
|
||||||
|
int vi;
|
||||||
|
char *vs;
|
||||||
|
void *vp;
|
||||||
|
|
||||||
|
switch (*f) {
|
||||||
|
case 'l':
|
||||||
|
case 'h':
|
||||||
|
case 'L':
|
||||||
|
case 'w':
|
||||||
|
continue;
|
||||||
|
case 'd':
|
||||||
|
case 'i':
|
||||||
|
case 'o':
|
||||||
|
case 'x':
|
||||||
|
case 'X':
|
||||||
|
case 'u':
|
||||||
|
vi = va_arg(ap, int);
|
||||||
|
len += (p > 0) ? p : 10;
|
||||||
|
break;
|
||||||
|
case 'f':
|
||||||
|
case 'g':
|
||||||
|
case 'e':
|
||||||
|
case 'G':
|
||||||
|
case 'E':
|
||||||
|
vd = va_arg(ap, double);
|
||||||
|
len += (p > 0) ? p : 15;
|
||||||
|
break;
|
||||||
|
case 'c':
|
||||||
|
len += 1;
|
||||||
|
vi = va_arg(ap, int);
|
||||||
|
break;
|
||||||
|
case 's':
|
||||||
|
vs = va_arg(ap, char *);
|
||||||
|
vi = strlen(vs);
|
||||||
|
len += (p > vi) ? p : vi;
|
||||||
|
break;
|
||||||
|
case 'p':
|
||||||
|
vp = va_arg(ap, void *);
|
||||||
|
len += 10;
|
||||||
|
break;
|
||||||
|
case 'n':
|
||||||
|
vp = va_arg(ap, void *);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
status = SP_NORMAL;
|
||||||
|
}
|
||||||
|
else if (IS_DIGIT(*f))
|
||||||
|
p = p * 10 + *f - '0';
|
||||||
|
else if (*f == '.')
|
||||||
|
status = SP_PREC2;
|
||||||
|
else if (*f == '%') {
|
||||||
|
status = SP_NORMAL;
|
||||||
|
len++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case SP_PREC2:
|
||||||
|
if (IS_ALPHA(*f)) {
|
||||||
|
status = SP_PREC;
|
||||||
|
goto redo;
|
||||||
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
va_end(ap);
|
}
|
||||||
|
va_end(ap);
|
||||||
n = (size_t) ret + 1;
|
s = Strnew_size(len * 2);
|
||||||
s = Strnew_size(n);
|
va_start(ap, fmt);
|
||||||
s->length = ret;
|
vsprintf(s->ptr, fmt, ap);
|
||||||
memcpy(s->ptr, cb, n);
|
va_end(ap);
|
||||||
free(cb);
|
s->length = strlen(s->ptr);
|
||||||
return s;
|
if (s->length > len * 2) {
|
||||||
|
fprintf(stderr, "Sprintf: string too long\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
Str
|
Str
|
||||||
|
4
cookie.c
4
cookie.c
@@ -461,9 +461,9 @@ save_cookies(void)
|
|||||||
for (p = First_cookie; p; p = p->next) {
|
for (p = First_cookie; p; p = p->next) {
|
||||||
if (!(p->flag & COO_USE) || p->flag & COO_DISCARD)
|
if (!(p->flag & COO_USE) || p->flag & COO_DISCARD)
|
||||||
continue;
|
continue;
|
||||||
fprintf(fp, "%s\t%s\t%s\t%lld\t%s\t%s\t%d\t%d\t%s\t%s\t%s\n",
|
fprintf(fp, "%s\t%s\t%s\t%ld\t%s\t%s\t%d\t%d\t%s\t%s\t%s\n",
|
||||||
parsedURL2Str(&p->url)->ptr,
|
parsedURL2Str(&p->url)->ptr,
|
||||||
p->name->ptr, p->value->ptr, (long long) p->expires,
|
p->name->ptr, p->value->ptr, (long)p->expires,
|
||||||
p->domain->ptr, p->path->ptr, p->flag,
|
p->domain->ptr, p->path->ptr, p->flag,
|
||||||
p->version, str2charp(p->comment),
|
p->version, str2charp(p->comment),
|
||||||
(p->portl) ? portlist2str(p->portl)->ptr : "",
|
(p->portl) ? portlist2str(p->portl)->ptr : "",
|
||||||
|
2
map.c
2
map.c
@@ -573,7 +573,7 @@ page_info_panel(Buffer *buf)
|
|||||||
"<tr valign=top><td nowrap>Number of lines<td>",
|
"<tr valign=top><td nowrap>Number of lines<td>",
|
||||||
Sprintf("%d", all)->ptr,
|
Sprintf("%d", all)->ptr,
|
||||||
"<tr valign=top><td nowrap>Transferred bytes<td>",
|
"<tr valign=top><td nowrap>Transferred bytes<td>",
|
||||||
Sprintf("%zu", buf->trbyte)->ptr, NULL);
|
Sprintf("%lu", (unsigned long)buf->trbyte)->ptr, NULL);
|
||||||
|
|
||||||
a = retrieveCurrentAnchor(buf);
|
a = retrieveCurrentAnchor(buf);
|
||||||
if (a != NULL) {
|
if (a != NULL) {
|
||||||
|
Reference in New Issue
Block a user