|
|
1.1 root 1: /*
2: * Copyright (c) 1980 Regents of the University of California.
3: * All rights reserved.
4: *
5: * Redistribution and use in source and binary forms are permitted
6: * provided that the above copyright notice and this paragraph are
7: * duplicated in all such forms and that any documentation,
8: * advertising materials, and other materials related to such
9: * distribution and use acknowledge that the software was developed
10: * by the University of California, Berkeley. The name of the
11: * University may not be used to endorse or promote products derived
12: * from this software without specific prior written permission.
13: * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
14: * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
15: * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
16: */
17:
18: #ifndef lint
19: char copyright[] =
20: "@(#) Copyright (c) 1980 Regents of the University of California.\n\
21: All rights reserved.\n";
22: #endif /* not lint */
23:
24: #ifndef lint
25: static char sccsid[] = "@(#)colrm.c 5.3 (Berkeley) 6/29/88";
26: #endif /* not lint */
27:
28: #include <stdio.h>
29: /*
30: COLRM removes unwanted columns from a file
31: Jeff Schriebman UC Berkeley 11-74
32: */
33:
34:
35: main(argc,argv)
36: char **argv;
37: {
38: register c, ct, first, last;
39:
40: first = 0;
41: last = 0;
42: if (argc > 1)
43: first = getn(*++argv);
44: if (argc > 2)
45: last = getn(*++argv);
46:
47: start:
48: ct = 0;
49: loop1:
50: c = getc(stdin);
51: if (feof(stdin))
52: goto fin;
53: if (c == '\t')
54: ct = (ct + 8) & ~7;
55: else if (c == '\b')
56: ct = ct ? ct - 1 : 0;
57: else
58: ct++;
59: if (c == '\n') {
60: putc(c, stdout);
61: goto start;
62: }
63: if (!first || ct < first) {
64: putc(c, stdout);
65: goto loop1;
66: }
67:
68: /* Loop getting rid of characters */
69: while (!last || ct < last) {
70: c = getc(stdin);
71: if (feof(stdin))
72: goto fin;
73: if (c == '\n') {
74: putc(c, stdout);
75: goto start;
76: }
77: if (c == '\t')
78: ct = (ct + 8) & ~7;
79: else if (c == '\b')
80: ct = ct ? ct - 1 : 0;
81: else
82: ct++;
83: }
84:
85: /* Output last of the line */
86: for (;;) {
87: c = getc(stdin);
88: if (feof(stdin))
89: break;
90: putc(c, stdout);
91: if (c == '\n')
92: goto start;
93: }
94: fin:
95: fflush(stdout);
96: exit(0);
97: }
98:
99: getn(ap)
100: char *ap;
101: {
102: register int n,c;
103: register char *p;
104:
105: p = ap;
106: n = 0;
107: while ((c = *p++) >= '0' && c <= '9')
108: n = n*10 + c - '0';
109: return(n);
110: }
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.