Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.sbin/lastlogin Output records in original order



details:   https://anonhg.NetBSD.org/src/rev/2cb8fba56902
branches:  trunk
changeset: 1009893:2cb8fba56902
user:      kim <kim%NetBSD.org@localhost>
date:      Wed May 06 19:45:39 2020 +0000

description:
Output records in original order

Append to the list of output records instead of pushing on it, so we
don't reverse the order of records (when not sorting).

diffstat:

 usr.sbin/lastlogin/lastlogin.c |  23 +++++++++++------------
 1 files changed, 11 insertions(+), 12 deletions(-)

diffs (78 lines):

diff -r 1a3071c21d0d -r 2cb8fba56902 usr.sbin/lastlogin/lastlogin.c
--- a/usr.sbin/lastlogin/lastlogin.c    Wed May 06 19:45:12 2020 +0000
+++ b/usr.sbin/lastlogin/lastlogin.c    Wed May 06 19:45:39 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: lastlogin.c,v 1.18 2020/05/06 19:31:32 kim Exp $       */
+/*     $NetBSD: lastlogin.c,v 1.19 2020/05/06 19:45:39 kim Exp $       */
 /*
  * Copyright (c) 1996 John M. Vinopal
  * All rights reserved.
@@ -33,7 +33,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: lastlogin.c,v 1.18 2020/05/06 19:31:32 kim Exp $");
+__RCSID("$NetBSD: lastlogin.c,v 1.19 2020/05/06 19:45:39 kim Exp $");
 #endif
 
 #include <sys/types.h>
@@ -95,6 +95,7 @@
 #define DOSORT(x)      ((x) & (SORT_TIME))
 static int sortlog = SORT_NONE;
 static struct output *outstack = NULL;
+static struct output *outstack_p = NULL;
 
 static int fixed = 0;
 #define FIXED_NAMELEN  UT_NAMESIZE
@@ -121,7 +122,7 @@
 static void            process_entryx(struct passwd *, struct lastlogx *);
 static void            dolastlogx(const char *, int, char *[]);
 #endif
-static void            push_record(struct output *);
+static void            append_record(struct output *);
 static void            sizecolumns(struct output *);
 static void            output_stack(struct output *);
 static void            sort_and_output_stack(struct output *);
@@ -289,7 +290,7 @@
         * onto a stack.  Otherwise, we can just output it.
         */
        if (SIZECOLUMNS || DOSORT(sortlog))
-               push_record(&o);
+               append_record(&o);
        else
                output_record(&o);
 }
@@ -417,14 +418,14 @@
         * onto a stack.  Otherwise, we can just output it.
         */
        if (SIZECOLUMNS || DOSORT(sortlog))
-               push_record(&o);
+               append_record(&o);
        else
                output_record(&o);
 }
 #endif
 
 static void
-push_record(struct output *o)
+append_record(struct output *o)
 {
        struct output   *out;
 
@@ -434,12 +435,10 @@
        (void)memcpy(out, o, sizeof(*out));
        out->next = NULL;
 
-       if (outstack) {
-               out->next = outstack;
-               outstack = out;
-       } else {
-               outstack = out;
-       }
+       if (outstack_p)
+               outstack_p = outstack_p->next = out;
+       else
+               outstack = outstack_p = out;
 }
 
 static void



Home | Main Index | Thread Index | Old Index