blob: 53e3c64f29c421d48cbc1e8fc7044154b0b8ab5a [file] [log] [blame]
Erik Andersene49d5ec2000-02-08 19:58:47 +00001/* vi: set sw=4 ts=4: */
John Beppuabb47722000-01-06 00:48:21 +00002/*
Erik Andersen0b874ed2000-01-06 01:14:56 +00003 * Mini uniq implementation for busybox
John Beppuabb47722000-01-06 00:48:21 +00004 *
5 *
Eric Andersen8ec10a92001-01-27 09:33:39 +00006 * Copyright (C) 1999,2000,2001 by Lineo, inc.
John Beppuabb47722000-01-06 00:48:21 +00007 * Written by John Beppu <beppu@lineo.com>
Matt Kraaie0bcce02000-09-27 02:29:39 +00008 * Rewritten by Matt Kraai <kraai@alumni.carnegiemellon.edu>
John Beppuabb47722000-01-06 00:48:21 +00009 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 * General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23 *
24 */
25
John Beppuabb47722000-01-06 00:48:21 +000026#include <stdio.h>
John Beppu96f1f332000-01-06 23:49:21 +000027#include <string.h>
Eric Andersened3ef502001-01-27 08:24:39 +000028#include <getopt.h>
John Beppu96f1f332000-01-06 23:49:21 +000029#include <errno.h>
Eric Andersened3ef502001-01-27 08:24:39 +000030#include <stdlib.h>
Eric Andersencbe31da2001-02-20 06:14:08 +000031#include "busybox.h"
John Beppuabb47722000-01-06 00:48:21 +000032
Eric Andersen5b5db382000-12-09 16:37:53 +000033static int print_count;
34static int print_uniq = 1;
35static int print_duplicates = 1;
36
37static void print_line(char *line, int count, FILE *fp)
38{
39 if ((print_duplicates && count > 1) || (print_uniq && count == 1)) {
40 if (print_count)
41 fprintf(fp, "%7d\t%s", count, line);
42 else
43 fputs(line, fp);
44 }
45}
46
Erik Andersene49d5ec2000-02-08 19:58:47 +000047int uniq_main(int argc, char **argv)
John Beppuabb47722000-01-06 00:48:21 +000048{
Matt Kraaie0bcce02000-09-27 02:29:39 +000049 FILE *in = stdin, *out = stdout;
50 char *lastline = NULL, *input;
Eric Andersen5b5db382000-12-09 16:37:53 +000051 int opt, count = 0;
John Beppuabb47722000-01-06 00:48:21 +000052
Erik Andersene49d5ec2000-02-08 19:58:47 +000053 /* parse argv[] */
Eric Andersen5b5db382000-12-09 16:37:53 +000054 while ((opt = getopt(argc, argv, "cdu")) > 0) {
55 switch (opt) {
56 case 'c':
57 print_count = 1;
58 break;
59 case 'd':
60 print_duplicates = 1;
61 print_uniq = 0;
62 break;
63 case 'u':
64 print_duplicates = 0;
65 print_uniq = 1;
66 break;
67 }
68 }
Matt Kraaie0bcce02000-09-27 02:29:39 +000069
Eric Andersen5b5db382000-12-09 16:37:53 +000070 if (argv[optind] != NULL) {
71 in = xfopen(argv[optind], "r");
72 if (argv[optind+1] != NULL)
73 out = xfopen(argv[optind+1], "w");
Matt Kraaie0bcce02000-09-27 02:29:39 +000074 }
75
76 while ((input = get_line_from_file(in)) != NULL) {
77 if (lastline == NULL || strcmp(input, lastline) != 0) {
Eric Andersen5b5db382000-12-09 16:37:53 +000078 print_line(lastline, count, out);
Matt Kraaie0bcce02000-09-27 02:29:39 +000079 free(lastline);
80 lastline = input;
Eric Andersen5b5db382000-12-09 16:37:53 +000081 count = 0;
Erik Andersene49d5ec2000-02-08 19:58:47 +000082 }
Eric Andersen5b5db382000-12-09 16:37:53 +000083 count++;
John Beppuabb47722000-01-06 00:48:21 +000084 }
Eric Andersen5b5db382000-12-09 16:37:53 +000085 print_line(lastline, count, out);
Matt Kraaie0bcce02000-09-27 02:29:39 +000086 free(lastline);
John Beppuabb47722000-01-06 00:48:21 +000087
Matt Kraaie0bcce02000-09-27 02:29:39 +000088 return EXIT_SUCCESS;
John Beppuabb47722000-01-06 00:48:21 +000089}