Do not use C99 printf format specifiers and asprintf

This commit is contained in:
Tatsuya Kinoshita
2015-01-15 19:13:51 +09:00
parent ec8272d8fe
commit 5e9545756b
3 changed files with 98 additions and 22 deletions

114
Str.c
View File

@@ -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

View File

@@ -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
View File

@@ -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) {