xref: /csrg-svn/old/refer/hunt/hunt7.c (revision 48296)
1*48296Sbostic /*-
2*48296Sbostic  * %sccs.include.proprietary.c%
3*48296Sbostic  */
4*48296Sbostic 
512288Stut #ifndef lint
6*48296Sbostic static char sccsid[] = "@(#)hunt7.c	4.2 (Berkeley) 04/18/91";
7*48296Sbostic #endif /* not lint */
812288Stut 
912288Stut #include <stdio.h>
1012288Stut #include <assert.h>
1112288Stut #define SAME 0
1212288Stut #define FGCT 10
1312288Stut #define FGSIZE 150
1412288Stut 
1512288Stut int keepold = 1;	/* keep old things for fgrep search */
1612288Stut char fgspace[FGSIZE];
1712288Stut char *fgp = fgspace;
1812288Stut char *fgnames[FGCT];
1912288Stut char **fgnamp = fgnames;
2012288Stut 
findline(in,out,outlen,indexdate)2112288Stut findline(in, out, outlen, indexdate)
2212288Stut long indexdate;
2312288Stut char *in, *out;
2412288Stut {
2512288Stut 	static char name[100] = "";
2612288Stut 	char *p, **ftp;
2712288Stut 	extern long gdate();
2812288Stut 	static FILE *fa = NULL;
2912288Stut 	long lp, llen;
3012288Stut 	int len, k, nofil;
3112288Stut 
3212288Stut # if D1
3312288Stut 	fprintf(stderr, "findline: %s\n", in);
3412288Stut # endif
3512288Stut 	if (mindex(in, '!'))
3612288Stut 		return(remote(in, out));
3712288Stut 	nofil = in[0]==0;
3812288Stut 	for(p=in; *p && *p != ':' && *p != ';'; p++)
3912288Stut 		;
4012288Stut 	if (*p) *p++=0;
4112288Stut 	else p=in;
4212288Stut 	k = sscanf(p, "%ld,%ld", &lp, &llen);
4312288Stut # ifdef D1
4412288Stut 	fprintf(stderr, "p %s k %d lp %ld llen %ld\n",p,k,lp,llen);
4512288Stut # endif
4612288Stut 	if (k<2)
4712288Stut 	{
4812288Stut 		lp = 0;
4912288Stut 		llen=outlen;
5012288Stut 	}
5112288Stut # ifdef D1
5212288Stut 	fprintf(stderr, "lp %ld llen %ld\n",lp, llen);
5312288Stut # endif
5412288Stut # ifdef D1
5512288Stut 	fprintf(stderr, "fa now %o, p %o in %o %s\n",fa, p,in,in);
5612288Stut # endif
5712288Stut 	if (nofil)
5812288Stut 	{
5912288Stut # if D1
6012288Stut 		fprintf(stderr, "set fa to stdin\n");
6112288Stut # endif
6212288Stut 		fa = stdin;
6312288Stut 	}
6412288Stut 	else
6512288Stut 		if (strcmp (name, in) != 0 || 1)
6612288Stut 		{
6712288Stut # if D1
6812288Stut 			fprintf(stderr, "old: %s new %s not equal\n",name,in);
6912288Stut # endif
7012288Stut 			if (fa != NULL)
7112288Stut 				fa = freopen(in, "r", fa);
7212288Stut 			else
7312288Stut 				fa = fopen(in, "r");
7412288Stut # if D1
7512288Stut 			if (fa==NULL)
7612288Stut 				fprintf(stderr, "failed to (re)open *%s*\n",in);
7712288Stut # endif
7812288Stut 			if (fa == NULL)
7912288Stut 				return(0);
8012288Stut 			/* err("Can't open %s", in); */
8112288Stut 			strcpy(name, in);
8212288Stut 			if (gdate(fa) > indexdate && indexdate != 0)
8312288Stut 			{
8412288Stut 				if (keepold)
8512288Stut 				{
8612288Stut 					for(ftp=fgnames; ftp<fgnamp; ftp++)
8712288Stut 						if (strcmp(*ftp, name)==SAME)
8812288Stut 							return(0);
8912288Stut 					strcpy (*fgnamp++ = fgp, name);
9012288Stut 					assert(fgnamp<fgnames+FGCT);
9112288Stut 					while (*fgp && *fgp!=':')
9212288Stut 						fgp++;
9312288Stut 					*fgp++ = 0;
9412288Stut 					assert (fgp<fgspace+FGSIZE);
9512288Stut 					return(0);
9612288Stut 				}
9712288Stut 				fprintf(stderr, "Warning: index predates file '%s'\n", name);
9812288Stut 			}
9912288Stut 		}
10012288Stut # if D1
10112288Stut 		else
10212288Stut 			fprintf(stderr, "old %s new %s same fa %o\n", name,in,fa);
10312288Stut # endif
10412288Stut 	if (fa != NULL)
10512288Stut 	{
10612288Stut 		fseek (fa, lp, 0);
10712288Stut 		len = (llen >= outlen) ? outlen-1 : llen;
10812288Stut 		len = fread (out, 1, len, fa);
10912288Stut 		out[len] = 0;
11012288Stut # ifdef D1
11112288Stut 		fprintf(stderr, "length as read is %d\n",len);
11212288Stut # endif
11312288Stut 	}
11412288Stut 	return(len);
11512288Stut }
116