summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>1996-04-10 03:50:31 +0000
committerJim Meyering <jim@meyering.net>1996-04-10 03:50:31 +0000
commit727a9ed9701da376b4411129771e7526783e1ffe (patch)
treea651bbaabd58404f6b793a0230b21dbfd1c2a6c2 /src
parent5d5979d9a8d187aed2d82269ffc2388029319f85 (diff)
downloadcoreutils-727a9ed9701da376b4411129771e7526783e1ffe.tar.xz
Add new option --ignore-case (-i).
Include memcasecmp.h. (different): Compare with memcasecmp if ignoring case. (main): Handle 'i'.
Diffstat (limited to 'src')
-rw-r--r--src/uniq.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/src/uniq.c b/src/uniq.c
index 6d5a26468..91dd93c9f 100644
--- a/src/uniq.c
+++ b/src/uniq.c
@@ -42,6 +42,7 @@
#include "linebuffer.h"
#include "error.h"
#include "xstrtol.h"
+#include "memcasecmp.h"
/* Undefine, to avoid warning about redefinition on some systems. */
#undef min
@@ -79,6 +80,9 @@ enum output_mode
/* Which lines to output. */
static enum output_mode mode;
+/* If nonzero, ignore case when comparing. */
+static int ignore_case;
+
/* If nonzero, display usage information and exit. */
static int show_help;
@@ -89,6 +93,7 @@ static struct option const longopts[] =
{
{"count", no_argument, NULL, 'c'},
{"repeated", no_argument, NULL, 'd'},
+ {"ignore-case", no_argument, NULL, 'i'},
{"unique", no_argument, NULL, 'u'},
{"skip-fields", required_argument, NULL, 'f'},
{"skip-chars", required_argument, NULL, 's'},
@@ -117,6 +122,7 @@ standard input), writing to OUTPUT (or standard output).\n\
-c, --count prefix lines by the number of occurrences\n\
-d, --repeated only print duplicate lines\n\
-f, --skip-fields=N avoid comparing the first N fields\n\
+ -i, --ignore-case ignore differences in case when comparing\n\
-s, --skip-chars=N avoid comparing the first N characters\n\
-u, --unique only print unique lines\n\
-w, --check-chars=N compare no more than N characters in lines\n\
@@ -174,12 +180,20 @@ different (const char *old, const char *new, int oldlen, int newlen)
if (newlen > check_chars)
newlen = check_chars;
}
- order = memcmp (old, new, min (oldlen, newlen));
+
+ /* Use an if-statement here rather than a function variable to
+ avoid portability hassles of getting a non-conflicting declaration
+ of memcmp. */
+ if (ignore_case)
+ order = memcasecmp (old, new, min (oldlen, newlen));
+ else
+ order = memcmp (old, new, min (oldlen, newlen));
+
if (order == 0)
return oldlen - newlen;
return order;
}
-
+
/* Output the line in linebuffer LINE to stream STREAM
provided that the switches say it should be output.
If requested, print the number of times it occurred, as well;
@@ -289,7 +303,7 @@ main (int argc, char **argv)
mode = output_all;
countmode = count_none;
- while ((optc = getopt_long (argc, argv, "0123456789cdf:s:uw:", longopts,
+ while ((optc = getopt_long (argc, argv, "0123456789cdf:is:uw:", longopts,
(int *) 0)) != EOF)
{
switch (optc)
@@ -330,6 +344,10 @@ main (int argc, char **argv)
}
break;
+ case 'i':
+ ignore_case = 1;
+ break;
+
case 's': /* Like '+#'. */
{
long int tmp_long;