File:  [Research Unix] / researchv10no / cmd / cmp.c
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs
Tue Apr 24 17:21:34 2018 UTC (8 years, 1 month ago) by root
Branches: belllabs, MAIN
CVS tags: researchv10, HEAD
researchv10 Norman

#define BUF	4096

int sflag = 0;
int lflag = 0;
int Lflag = 0;

main(argc, argv)
	char **argv;
{
	register n1, n2, n;
	unsigned char buf1[BUF], buf2[BUF];
	register unsigned char *p, *q;
	int f1, f2, i, nn;
	long nc = 1, o, atol(), l=1, l1;
	char *name1, *name2, *a;
	unsigned char *b1s, *b1e, *b2s, *b2e;

	for(n=1; n<argc && (*argv[n] == '-'); n++)
		for(a = &argv[n][1]; *a; a++)
			switch(*a) {
			case 's':	sflag = 1; break;
			case 'l':	lflag = 1; break;
			case 'L':	Lflag = 1; break;
			default:	usage();
			}
	if(n > argc-2)
		usage();
	if((f1 = open(name1 = argv[n++], 0)) == -1)
		argerr(name1);
	if((f2 = open(name2 = argv[n++], 0)) == -1)
		argerr(name2);
	if(n < argc){
		o = atol(argv[n++]);
		if(lseek(f1, o, 0) < 0)
			argerr("cmp: lseek by offset1");
	}
	if(n < argc){
		o = atol(argv[n++]);
		if(lseek(f2, o, 0) < 0)
			argerr("cmp: lseek by offset2");
	}
	if(n < argc)
		usage();
	b1s = b1e = buf1;
	b2s = b2e = buf2;
	for(;;){
		if(b1s >= b1e){
			if(b1s >= &buf1[BUF])
				b1s = buf1;
			n1 = read(f1, b1s,  &buf1[BUF] - b1s);
			b1e = b1s + n1;
		}
		if(b2s >= b2e){
			if(b2s >= &buf2[BUF])
				b2s = buf2;
			n2 = read(f2, b2s,  &buf2[BUF] - b2s);
			b2e = b2s + n2;
		}
		n = n2;
		if(n1 < n2) n = n1;
		if(n <= 0)
			break;
		if(memcmp(b1s, b2s, n) != 0){
			if(sflag)
				exit(1);
			l1 = 0;
			for(p = b1s, q = b2s, i = 0, nn = n; nn > 0; nn--, p++, q++, i++) {
				if(*p=='\n')
					l1++;
				if(*p != *q){
					if(!lflag){
						printf("%s %s differ: char %d",
						    name1, name2, nc+i);
						printf(Lflag?" line %d\n":"\n", l+l1);
						exit(1);
					}
					printf("%6ld %3o %3o\n", nc+i, *p, *q);
				}
			}
		}		
		if(Lflag)
			for(p = b1s; p < b1e;)
				if(*p++=='\n')
					l++;
		nc += n;
		b1s += n;
		b2s += n;
	}
	if(n1 == n2)
		exit(0);
	if(!sflag)
		printf("EOF on %s\n", (n1 > n2)? name2 : name1);
	exit(1);
}

long
atol(s)
char *s;
{
	long n;
	int f;

	n = 0;
	f = 0;
	while (*s == ' ' || *s == '\t')
		s++;
	if (*s == '-') {
		f = 1;
		s++;
	}
	if (s[0] == '0' && s[1]){
		if (s[1] == 'x' || s[1] == 'X') {
			s += 2;
			for (;;) {
				if (*s >= '0' && *s <= '9')
					n = n*16 + *s++ - '0';
				else if (*s >= 'a' && *s <= 'f')
					n = n*16 + *s++ - 'a' + 10;
				else if (*s >= 'A' && *s <= 'F')
					n = n*16 + *s++ - 'A' + 10;
				else
					break;
			}
		}
		else
			while (*s >= '0' && *s <= '7')
				n = n*8 + *s++ - '0';
	}
	else
		while (*s >= '0' && *s <= '9')
			n = n*10 + *s++ - '0';
	if (f)
		n = -n;
	return n;
}

argerr(s)
char *s;
{
	if(sflag == 0)
		perror(s);
	exit(2);
}

usage()
{
	printf("Usage: cmp [-ls] file1 file2 [offset1 [offset2] ]\n");
	exit(2);
}

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.