Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/stat - if st_dev/st_rdev == NODEV print -1 instead o...
details: https://anonhg.NetBSD.org/src/rev/89e1e282f64c
branches: trunk
changeset: 356346:89e1e282f64c
user: christos <christos%NetBSD.org@localhost>
date: Tue Sep 19 21:45:28 2017 +0000
description:
- if st_dev/st_rdev == NODEV print -1 instead of unsigned
- update to the latest linux stat(1) format for -x (kind of)
- add the ability to display nanoseconds, like linux does
- change u_intX_t -> uintX_t
diffstat:
usr.bin/stat/stat.1 | 10 +++++---
usr.bin/stat/stat.c | 61 +++++++++++++++++++++++++++++++++++++++-------------
2 files changed, 51 insertions(+), 20 deletions(-)
diffs (170 lines):
diff -r e6fc9718e4d0 -r 89e1e282f64c usr.bin/stat/stat.1
--- a/usr.bin/stat/stat.1 Tue Sep 19 20:46:12 2017 +0000
+++ b/usr.bin/stat/stat.1 Tue Sep 19 21:45:28 2017 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: stat.1,v 1.38 2017/07/03 21:34:21 wiz Exp $
+.\" $NetBSD: stat.1,v 1.39 2017/09/19 21:45:28 christos Exp $
.\"
.\" Copyright (c) 2002-2011 The NetBSD Foundation, Inc.
.\" All rights reserved.
@@ -27,7 +27,7 @@
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
.\" POSSIBILITY OF SUCH DAMAGE.
.\"
-.Dd December 2, 2012
+.Dd September 19, 2017
.Dt STAT 1
.Os
.Sh NAME
@@ -183,7 +183,8 @@
Display timestamps using the specified format.
This format is
passed directly to
-.Xr strftime 3 .
+.Xr strftime 3
+with the extension that %f prints nanoseconds if available.
.It Fl v
Turn off quiet mode.
.It Fl x
@@ -274,7 +275,8 @@
May be used in combination with
.Bl -tag -width Ds
.It Cm amc
-Display date in strftime(3) format.
+Display date in strftime(3) format
+with the extension that %f prints nanoseconds if available.
.It Cm dr
Display actual device name.
.It Cm gu
diff -r e6fc9718e4d0 -r 89e1e282f64c usr.bin/stat/stat.c
--- a/usr.bin/stat/stat.c Tue Sep 19 20:46:12 2017 +0000
+++ b/usr.bin/stat/stat.c Tue Sep 19 21:45:28 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: stat.c,v 1.38 2013/01/03 13:28:41 dsl Exp $ */
+/* $NetBSD: stat.c,v 1.39 2017/09/19 21:45:28 christos Exp $ */
/*
* Copyright (c) 2002-2011 The NetBSD Foundation, Inc.
@@ -37,7 +37,7 @@
#include <sys/cdefs.h>
#if !defined(lint)
-__RCSID("$NetBSD: stat.c,v 1.38 2013/01/03 13:28:41 dsl Exp $");
+__RCSID("$NetBSD: stat.c,v 1.39 2017/09/19 21:45:28 christos Exp $");
#endif
#if ! HAVE_NBTOOL_CONFIG_H
@@ -105,12 +105,13 @@
"st_blksize=%k st_blocks=%b" SHELL_F
#define LINUX_FORMAT \
" File: \"%N\"%n" \
- " Size: %-11z FileType: %HT%n" \
+ " Size: %-11z Blocks: %-11b IO Block: %-11k %HT%n" \
+ "Device: %Hd,%Ld Inode: %i Links: %l%n" \
" Mode: (%04OLp/%.10Sp) Uid: (%5u/%8Su) Gid: (%5g/%8Sg)%n" \
- "Device: %Hd,%Ld Inode: %i Links: %l%n" \
"Access: %Sa%n" \
"Modify: %Sm%n" \
- "Change: %Sc"
+ "Change: %Sc%n" \
+ " Birth: %SB"
#define TIME_FORMAT "%b %e %T %Y"
@@ -262,6 +263,7 @@
errx(1, "can't use format '%c' with '%c'",
fmtchar, ch);
fmtchar = ch;
+ timefmt = "%Y-%m-%d %H:%M:%S.%f %z";
break;
case 't':
timefmt = optarg;
@@ -561,6 +563,34 @@
(void)fflush(stdout);
}
+static const char *
+fmttime(char *buf, size_t len, const char *fmt, time_t secs, long nsecs)
+{
+ struct tm tm;
+ char *fmt2;
+ if (localtime_r(&secs, &tm) == NULL) {
+ secs = 0;
+ (void)localtime_r(&secs, &tm);
+ }
+ if ((fmt2 = strstr(fmt, "%f")) != NULL) {
+ size_t flen = strlen(fmt) + 1024;
+ size_t o = (size_t)(fmt2 - fmt);
+ fmt2 = calloc(flen, 1);
+ if (fmt2 != NULL) {
+ memcpy(fmt2, fmt, o);
+ int sl = snprintf(fmt2 + o, flen - o, "%.9ld", nsecs);
+ if (sl == -1)
+ sl = 0;
+ strcpy(fmt2 + sl + o, fmt + o + 2);
+ fmt = fmt2;
+ }
+ }
+
+ (void)strftime(buf, len, fmt, &tm);
+ free(fmt2);
+ return buf;
+}
+
/*
* Arranges output according to a single parsed format substring.
*/
@@ -572,13 +602,12 @@
int flags, int size, int prec, int ofmt,
int hilo, int what, int quiet)
{
- u_int64_t data;
+ uint64_t data;
char *stmp, lfmt[24], tmp[20];
const char *sdata;
char smode[12], sid[12], path[PATH_MAX + 4], visbuf[PATH_MAX * 4 + 4];
struct passwd *pw;
struct group *gr;
- struct tm *tm;
time_t secs;
long nsecs;
int l;
@@ -629,8 +658,12 @@
#else /* HAVE_DEVNAME */
0;
#endif /* HAVE_DEVNAME */
- if (ofmt == 0)
- ofmt = FMTF_UNSIGNED;
+ if (ofmt == 0) {
+ if (data == (uint64_t)-1)
+ ofmt = FMTF_DECIMAL;
+ else
+ ofmt = FMTF_UNSIGNED;
+ }
break;
case SHOW_st_ino:
small = (sizeof(st->st_ino) == 4);
@@ -745,12 +778,8 @@
#endif /* HAVE_STRUCT_STAT_ST_BIRTHTIME */
small = (sizeof(secs) == 4);
data = secs;
- tm = localtime(&secs);
- if (tm == NULL) {
- secs = 0;
- tm = localtime(&secs);
- }
- (void)strftime(path, sizeof(path), timefmt, tm);
+ sdata = fmttime(path, sizeof(path), timefmt, secs, nsecs);
+
sdata = path;
formats = FMTF_DECIMAL | FMTF_OCTAL | FMTF_UNSIGNED | FMTF_HEX |
FMTF_FLOAT | FMTF_STRING;
@@ -1124,7 +1153,7 @@
* for some forms.
*/
if (small && ofmt != FMTF_DECIMAL)
- data = (u_int32_t)data;
+ data = (uint32_t)data;
/*
* The four "numeric" output forms.
Home |
Main Index |
Thread Index |
Old Index