svn commit: r332482 - in stable/11/usr.bin: head tail

Kyle Evans kevans at FreeBSD.org
Fri Apr 13 17:57:01 UTC 2018


Author: kevans
Date: Fri Apr 13 17:57:00 2018
New Revision: 332482
URL: https://svnweb.freebsd.org/changeset/base/332482

Log:
  MFC r332372-r332374: tail(1)/head(1) compatibility long options
  
  r332372:
  tail(1): Add some long options
  
  Add --blocks, --bytes, and --lines long options for -b, -c, and -n
  respectively. This improves tail(1)'s compatibility with its GNU counterpart
  in a straightforward way.
  
  r332373:
  tail(1): Address mandoc concern (space before punctuation after macro)
  
  r332374:
  head(1): Provide long options
  
  Provide long options --bytes and --lines to match -c and -n respectively.
  This improves head(1)'s compatibility with its GNU counterpart in a sensible
  way.

Modified:
  stable/11/usr.bin/head/head.1
  stable/11/usr.bin/head/head.c
  stable/11/usr.bin/tail/tail.1
  stable/11/usr.bin/tail/tail.c
Directory Properties:
  stable/11/   (props changed)

Modified: stable/11/usr.bin/head/head.1
==============================================================================
--- stable/11/usr.bin/head/head.1	Fri Apr 13 17:45:54 2018	(r332481)
+++ stable/11/usr.bin/head/head.1	Fri Apr 13 17:57:00 2018	(r332482)
@@ -28,7 +28,7 @@
 .\"	@(#)head.1	8.1 (Berkeley) 6/6/93
 .\" $FreeBSD$
 .\"
-.Dd March 16, 2013
+.Dd April 10, 2018
 .Dt HEAD 1
 .Os
 .Sh NAME
@@ -48,6 +48,18 @@ files are specified.
 If
 .Ar count
 is omitted it defaults to 10.
+.Pp
+The following options are available:
+.Bl -tag -width indent
+.It Fl c Ar bytes , Fl -bytes Ns = Ns Ar bytes
+Print
+.Ar bytes
+of each of the specified files.
+.It Fl n Ar count , Fl -lines Ns = Ns Ar count
+Print
+.Ar count
+lines of each of the specified files.
+.El
 .Pp
 If more than a single file is specified, each file is preceded by a
 header consisting of the string

Modified: stable/11/usr.bin/head/head.c
==============================================================================
--- stable/11/usr.bin/head/head.c	Fri Apr 13 17:45:54 2018	(r332481)
+++ stable/11/usr.bin/head/head.c	Fri Apr 13 17:57:00 2018	(r332482)
@@ -45,6 +45,7 @@ __FBSDID("$FreeBSD$");
 
 #include <ctype.h>
 #include <err.h>
+#include <getopt.h>
 #include <inttypes.h>
 #include <stdio.h>
 #include <stdlib.h>
@@ -62,6 +63,13 @@ static void head_bytes(FILE *, off_t);
 static void obsolete(char *[]);
 static void usage(void);
 
+static const struct option long_opts[] =
+{
+	{"bytes",	required_argument,	NULL, 'c'},
+	{"lines",	required_argument,	NULL, 'n'},
+	{NULL,		no_argument,		NULL, 0}
+};
+
 int
 main(int argc, char *argv[])
 {
@@ -72,7 +80,7 @@ main(int argc, char *argv[])
 	char *ep;
 
 	obsolete(argv);
-	while ((ch = getopt(argc, argv, "n:c:")) != -1)
+	while ((ch = getopt_long(argc, argv, "+n:c:", long_opts, NULL)) != -1)
 		switch(ch) {
 		case 'c':
 			bytecnt = strtoimax(optarg, &ep, 10);

Modified: stable/11/usr.bin/tail/tail.1
==============================================================================
--- stable/11/usr.bin/tail/tail.1	Fri Apr 13 17:45:54 2018	(r332481)
+++ stable/11/usr.bin/tail/tail.1	Fri Apr 13 17:57:00 2018	(r332482)
@@ -31,7 +31,7 @@
 .\"	@(#)tail.1	8.1 (Berkeley) 6/6/93
 .\" $FreeBSD$
 .\"
-.Dd March 16, 2013
+.Dd April 10, 2018
 .Dt TAIL 1
 .Os
 .Sh NAME
@@ -73,11 +73,11 @@ or the last 10 lines of the input.
 .Pp
 The options are as follows:
 .Bl -tag -width indent
-.It Fl b Ar number
+.It Fl b Ar number , Fl -blocks Ns = Ns Ar number
 The location is
 .Ar number
 512-byte blocks.
-.It Fl c Ar number
+.It Fl c Ar number , Fl -bytes Ns = Ns Ar number
 The location is
 .Ar number
 bytes.
@@ -112,7 +112,7 @@ The
 option is the same as the
 .Fl f
 option if reading from standard input rather than a file.
-.It Fl n Ar number
+.It Fl n Ar number , Fl -lines Ns = Ns Ar number
 The location is
 .Ar number
 lines.

Modified: stable/11/usr.bin/tail/tail.c
==============================================================================
--- stable/11/usr.bin/tail/tail.c	Fri Apr 13 17:45:54 2018	(r332481)
+++ stable/11/usr.bin/tail/tail.c	Fri Apr 13 17:57:00 2018	(r332482)
@@ -49,6 +49,7 @@ static const char sccsid[] = "@(#)tail.c	8.1 (Berkeley
 
 #include <err.h>
 #include <errno.h>
+#include <getopt.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
@@ -63,6 +64,14 @@ static file_info_t *files;
 static void obsolete(char **);
 static void usage(void);
 
+static const struct option long_opts[] =
+{
+	{"blocks",	required_argument,	NULL, 'b'},
+	{"bytes",	required_argument,	NULL, 'c'},
+	{"lines",	required_argument,	NULL, 'n'},
+	{NULL,		no_argument,		NULL, 0}
+};
+
 int
 main(int argc, char *argv[])
 {
@@ -111,7 +120,8 @@ main(int argc, char *argv[])
 	obsolete(argv);
 	style = NOTSET;
 	off = 0;
-	while ((ch = getopt(argc, argv, "Fb:c:fn:qr")) != -1)
+	while ((ch = getopt_long(argc, argv, "+Fb:c:fn:qr", long_opts, NULL)) !=
+	    -1)
 		switch(ch) {
 		case 'F':	/* -F is superset of (and implies) -f */
 			Fflag = fflag = 1;


More information about the svn-src-all mailing list