mirror of
https://github.com/rkd77/elinks.git
synced 2025-01-03 14:57:44 -05:00
Route time_t-to-string conversions via time_print_T and TIME_PRINT_FORMAT.
The previous code just printed time_t directly with "%ld". Now it instead first casts to time_print_T (currently long) and then formats with TIME_PRINT_FORMAT (currently "ld"). So the varargs will now always match with the format string, even if time_t is longer than long. This still doesn't correctly format time_t values larger than LONG_MAX, though. But now it is at least easier to find some of the places that need to be changed to support that. I located these time_t-to-string conversions by searching for str_to_time_t, expires, and last_visit. There are still more places that assume every interesting time_t value fits either in 32 bits or in a long, e.g. in the cookie editor and in the ECMAScript interface. Inspired by bug 6.
This commit is contained in:
parent
ec1bedc25e
commit
f0dfd0504f
@ -456,9 +456,9 @@ set_cookie(struct uri *uri, unsigned char *str)
|
|||||||
#ifdef DEBUG_COOKIES
|
#ifdef DEBUG_COOKIES
|
||||||
{
|
{
|
||||||
DBG("Got cookie %s = %s from %s, domain %s, "
|
DBG("Got cookie %s = %s from %s, domain %s, "
|
||||||
"expires at %d, secure %d", cookie->name,
|
"expires at %"TIME_PRINT_FORMAT", secure %d", cookie->name,
|
||||||
cookie->value, cookie->server->host, cookie->domain,
|
cookie->value, cookie->server->host, cookie->domain,
|
||||||
cookie->expires, cookie->secure);
|
(time_print_T) cookie->expires, cookie->secure);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -672,8 +672,8 @@ send_cookies(struct uri *uri)
|
|||||||
|
|
||||||
if (c->expires && c->expires <= now) {
|
if (c->expires && c->expires <= now) {
|
||||||
#ifdef DEBUG_COOKIES
|
#ifdef DEBUG_COOKIES
|
||||||
DBG("Cookie %s=%s (exp %d) expired.",
|
DBG("Cookie %s=%s (exp %"TIME_PRINT_FORMAT") expired.",
|
||||||
c->name, c->value, c->expires);
|
c->name, c->value, (time_print_T) c->expires);
|
||||||
#endif
|
#endif
|
||||||
delete_cookie(c);
|
delete_cookie(c);
|
||||||
|
|
||||||
@ -878,12 +878,12 @@ save_cookies(struct terminal *term) {
|
|||||||
now = time(NULL);
|
now = time(NULL);
|
||||||
foreach (c, cookies) {
|
foreach (c, cookies) {
|
||||||
if (!c->expires || c->expires <= now) continue;
|
if (!c->expires || c->expires <= now) continue;
|
||||||
if (secure_fprintf(ssi, "%s\t%s\t%s\t%s\t%s\t%ld\t%d\n",
|
if (secure_fprintf(ssi, "%s\t%s\t%s\t%s\t%s\t%"TIME_PRINT_FORMAT"\t%d\n",
|
||||||
c->name, c->value,
|
c->name, c->value,
|
||||||
c->server->host,
|
c->server->host,
|
||||||
empty_string_or_(c->path),
|
empty_string_or_(c->path),
|
||||||
empty_string_or_(c->domain),
|
empty_string_or_(c->domain),
|
||||||
c->expires, c->secure) < 0)
|
(time_print_T) c->expires, c->secure) < 0)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -393,10 +393,11 @@ write_global_history(void)
|
|||||||
if (!ssi) return;
|
if (!ssi) return;
|
||||||
|
|
||||||
foreachback (history_item, global_history.entries) {
|
foreachback (history_item, global_history.entries) {
|
||||||
if (secure_fprintf(ssi, "%s\t%s\t%ld\n",
|
if (secure_fprintf(ssi, "%s\t%s\t%"TIME_PRINT_FORMAT"\n",
|
||||||
history_item->title,
|
history_item->title,
|
||||||
history_item->url,
|
history_item->url,
|
||||||
history_item->last_visit) < 0) break;
|
(time_print_T) history_item->last_visit) < 0)
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!secure_close(ssi)) global_history.dirty = 0;
|
if (!secure_close(ssi)) global_history.dirty = 0;
|
||||||
|
@ -19,6 +19,11 @@ typedef long milliseconds_T;
|
|||||||
/* Is using atol() in this way acceptable? It seems
|
/* Is using atol() in this way acceptable? It seems
|
||||||
* non-portable to me; time_t might not be a long. -- Miciah */
|
* non-portable to me; time_t might not be a long. -- Miciah */
|
||||||
#define str_to_time_t(s) ((time_t) atol(s))
|
#define str_to_time_t(s) ((time_t) atol(s))
|
||||||
|
/* When formatting time_t values to be parsed with str_to_time_t,
|
||||||
|
* we first cast to time_print_T and then printf the result with
|
||||||
|
* TIME_PRINT_FORMAT. */
|
||||||
|
typedef long time_print_T;
|
||||||
|
#define TIME_PRINT_FORMAT "ld"
|
||||||
|
|
||||||
/* Redefine a timeval that has all fields signed so calculations
|
/* Redefine a timeval that has all fields signed so calculations
|
||||||
* will be simplified on rare systems that define timeval with
|
* will be simplified on rare systems that define timeval with
|
||||||
|
Loading…
Reference in New Issue
Block a user