sort is good to go.
This commit is contained in:
parent
ee512a3f86
commit
00417a38c1
@ -9,6 +9,7 @@
|
|||||||
with the 2.0.x Linux kernel.
|
with the 2.0.x Linux kernel.
|
||||||
* Added 'grep -q' thanks to a patch from "Konstantin Boldyshev"
|
* Added 'grep -q' thanks to a patch from "Konstantin Boldyshev"
|
||||||
<konst@voshod.com>.
|
<konst@voshod.com>.
|
||||||
|
* Implemented sort. -beppu
|
||||||
|
|
||||||
-Erik Andersen
|
-Erik Andersen
|
||||||
|
|
||||||
|
@ -256,11 +256,19 @@ sort_main(int argc, char **argv)
|
|||||||
opt = argv[i][1];
|
opt = argv[i][1];
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'g':
|
case 'g':
|
||||||
|
/* what's the diff between -g && -n? */
|
||||||
compare = compare_numeric;
|
compare = compare_numeric;
|
||||||
break;
|
break;
|
||||||
case 'h':
|
case 'h':
|
||||||
usage(sort_usage);
|
usage(sort_usage);
|
||||||
break;
|
break;
|
||||||
|
case 'n':
|
||||||
|
/* what's the diff between -g && -n? */
|
||||||
|
compare = compare_numeric;
|
||||||
|
break;
|
||||||
|
case 'r':
|
||||||
|
/* reverse */
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "sort: invalid option -- %c\n", opt);
|
fprintf(stderr, "sort: invalid option -- %c\n", opt);
|
||||||
usage(sort_usage);
|
usage(sort_usage);
|
||||||
@ -270,7 +278,9 @@ sort_main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* go through remaining args (if any) */
|
/* this could be factored better */
|
||||||
|
|
||||||
|
/* work w/ stdin */
|
||||||
if (i >= argc) {
|
if (i >= argc) {
|
||||||
while ( (l = line_newFromFile(stdin))) {
|
while ( (l = line_newFromFile(stdin))) {
|
||||||
list_insert(&list, l);
|
list_insert(&list, l);
|
||||||
@ -278,32 +288,25 @@ sort_main(int argc, char **argv)
|
|||||||
list_sort(&list, compare);
|
list_sort(&list, compare);
|
||||||
list_writeToFile(&list, stdout);
|
list_writeToFile(&list, stdout);
|
||||||
list_release(&list);
|
list_release(&list);
|
||||||
|
|
||||||
|
/* work w/ what's left in argv[] */
|
||||||
} else {
|
} else {
|
||||||
|
FILE *src;
|
||||||
|
|
||||||
for ( ; i < argc; i++) {
|
for ( ; i < argc; i++) {
|
||||||
|
src = fopen(argv[i], "r");
|
||||||
|
if (src == NULL) { break; }
|
||||||
|
while ( (l = line_newFromFile(src))) {
|
||||||
|
list_insert(&list, l);
|
||||||
}
|
}
|
||||||
|
fclose(src);
|
||||||
|
}
|
||||||
|
list_sort(&list, compare);
|
||||||
|
list_writeToFile(&list, stdout);
|
||||||
|
list_release(&list);
|
||||||
}
|
}
|
||||||
|
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* $Id: sort.c,v 1.7 1999/12/23 00:02:49 beppu Exp $ */
|
/* $Id: sort.c,v 1.8 1999/12/23 22:46:10 beppu Exp $ */
|
||||||
/*
|
|
||||||
* $Log: sort.c,v $
|
|
||||||
* Revision 1.7 1999/12/23 00:02:49 beppu
|
|
||||||
* implemented numeric sort (sort -g)
|
|
||||||
*
|
|
||||||
* Revision 1.6 1999/12/22 23:02:12 beppu
|
|
||||||
* oops.. qsort(2) misunderstanding on my part.
|
|
||||||
* it's ok, now.
|
|
||||||
*
|
|
||||||
* Revision 1.5 1999/12/22 22:27:01 beppu
|
|
||||||
* playing w/ $Log: sort.c,v $
|
|
||||||
* playing w/ Revision 1.7 1999/12/23 00:02:49 beppu
|
|
||||||
* playing w/ implemented numeric sort (sort -g)
|
|
||||||
* playing w/
|
|
||||||
* playing w/ Revision 1.6 1999/12/22 23:02:12 beppu
|
|
||||||
* playing w/ oops.. qsort(2) misunderstanding on my part.
|
|
||||||
* playing w/ it's ok, now.
|
|
||||||
* playing w/
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
47
sort.c
47
sort.c
@ -256,11 +256,19 @@ sort_main(int argc, char **argv)
|
|||||||
opt = argv[i][1];
|
opt = argv[i][1];
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'g':
|
case 'g':
|
||||||
|
/* what's the diff between -g && -n? */
|
||||||
compare = compare_numeric;
|
compare = compare_numeric;
|
||||||
break;
|
break;
|
||||||
case 'h':
|
case 'h':
|
||||||
usage(sort_usage);
|
usage(sort_usage);
|
||||||
break;
|
break;
|
||||||
|
case 'n':
|
||||||
|
/* what's the diff between -g && -n? */
|
||||||
|
compare = compare_numeric;
|
||||||
|
break;
|
||||||
|
case 'r':
|
||||||
|
/* reverse */
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "sort: invalid option -- %c\n", opt);
|
fprintf(stderr, "sort: invalid option -- %c\n", opt);
|
||||||
usage(sort_usage);
|
usage(sort_usage);
|
||||||
@ -270,7 +278,9 @@ sort_main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* go through remaining args (if any) */
|
/* this could be factored better */
|
||||||
|
|
||||||
|
/* work w/ stdin */
|
||||||
if (i >= argc) {
|
if (i >= argc) {
|
||||||
while ( (l = line_newFromFile(stdin))) {
|
while ( (l = line_newFromFile(stdin))) {
|
||||||
list_insert(&list, l);
|
list_insert(&list, l);
|
||||||
@ -278,32 +288,25 @@ sort_main(int argc, char **argv)
|
|||||||
list_sort(&list, compare);
|
list_sort(&list, compare);
|
||||||
list_writeToFile(&list, stdout);
|
list_writeToFile(&list, stdout);
|
||||||
list_release(&list);
|
list_release(&list);
|
||||||
|
|
||||||
|
/* work w/ what's left in argv[] */
|
||||||
} else {
|
} else {
|
||||||
|
FILE *src;
|
||||||
|
|
||||||
for ( ; i < argc; i++) {
|
for ( ; i < argc; i++) {
|
||||||
|
src = fopen(argv[i], "r");
|
||||||
|
if (src == NULL) { break; }
|
||||||
|
while ( (l = line_newFromFile(src))) {
|
||||||
|
list_insert(&list, l);
|
||||||
}
|
}
|
||||||
|
fclose(src);
|
||||||
|
}
|
||||||
|
list_sort(&list, compare);
|
||||||
|
list_writeToFile(&list, stdout);
|
||||||
|
list_release(&list);
|
||||||
}
|
}
|
||||||
|
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* $Id: sort.c,v 1.7 1999/12/23 00:02:49 beppu Exp $ */
|
/* $Id: sort.c,v 1.8 1999/12/23 22:46:10 beppu Exp $ */
|
||||||
/*
|
|
||||||
* $Log: sort.c,v $
|
|
||||||
* Revision 1.7 1999/12/23 00:02:49 beppu
|
|
||||||
* implemented numeric sort (sort -g)
|
|
||||||
*
|
|
||||||
* Revision 1.6 1999/12/22 23:02:12 beppu
|
|
||||||
* oops.. qsort(2) misunderstanding on my part.
|
|
||||||
* it's ok, now.
|
|
||||||
*
|
|
||||||
* Revision 1.5 1999/12/22 22:27:01 beppu
|
|
||||||
* playing w/ $Log: sort.c,v $
|
|
||||||
* playing w/ Revision 1.7 1999/12/23 00:02:49 beppu
|
|
||||||
* playing w/ implemented numeric sort (sort -g)
|
|
||||||
* playing w/
|
|
||||||
* playing w/ Revision 1.6 1999/12/22 23:02:12 beppu
|
|
||||||
* playing w/ oops.. qsort(2) misunderstanding on my part.
|
|
||||||
* playing w/ it's ok, now.
|
|
||||||
* playing w/
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user