aboutsummaryrefslogtreecommitdiff
path: root/miscutils
diff options
context:
space:
mode:
Diffstat (limited to 'miscutils')
-rw-r--r--miscutils/last_fancy.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/miscutils/last_fancy.c b/miscutils/last_fancy.c
index f687d7e16..16ed9e920 100644
--- a/miscutils/last_fancy.c
+++ b/miscutils/last_fancy.c
@@ -42,7 +42,7 @@ enum {
42static void show_entry(struct utmp *ut, int state, time_t dur_secs) 42static void show_entry(struct utmp *ut, int state, time_t dur_secs)
43{ 43{
44 unsigned days, hours, mins; 44 unsigned days, hours, mins;
45 char duration[32]; 45 char duration[sizeof("(%u+02:02)") + sizeof(int)*3];
46 char login_time[17]; 46 char login_time[17];
47 char logout_time[8]; 47 char logout_time[8];
48 const char *logout_str; 48 const char *logout_str;
@@ -53,7 +53,8 @@ static void show_entry(struct utmp *ut, int state, time_t dur_secs)
53 * but some systems have it wrong */ 53 * but some systems have it wrong */
54 tmp = ut->ut_tv.tv_sec; 54 tmp = ut->ut_tv.tv_sec;
55 safe_strncpy(login_time, ctime(&tmp), 17); 55 safe_strncpy(login_time, ctime(&tmp), 17);
56 snprintf(logout_time, 8, "- %s", ctime(&dur_secs) + 11); 56 tmp = dur_secs;
57 snprintf(logout_time, 8, "- %s", ctime(&tmp) + 11);
57 58
58 dur_secs = MAX(dur_secs - (time_t)ut->ut_tv.tv_sec, (time_t)0); 59 dur_secs = MAX(dur_secs - (time_t)ut->ut_tv.tv_sec, (time_t)0);
59 /* unsigned int is easier to divide than time_t (which may be signed long) */ 60 /* unsigned int is easier to divide than time_t (which may be signed long) */