| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 | 
							- #include "f2c.h"
 
- #include "fio.h"
 
- #ifdef __cplusplus
 
- extern "C" {
 
- #endif
 
- #ifdef KR_headers
 
- integer f_back(a) alist *a;
 
- #else
 
- integer f_back(alist *a)
 
- #endif
 
- {	unit *b;
 
- 	OFF_T v, w, x, y, z;
 
- 	uiolen n;
 
- 	FILE *f;
 
- 	f__curunit = b = &f__units[a->aunit];	/* curunit for error messages */
 
- 	if(a->aunit >= MXUNIT || a->aunit < 0)
 
- 		err(a->aerr,101,"backspace")
 
- 	if(b->useek==0) err(a->aerr,106,"backspace")
 
- 	if(b->ufd == NULL) {
 
- 		fk_open(1, 1, a->aunit);
 
- 		return(0);
 
- 		}
 
- 	if(b->uend==1)
 
- 	{	b->uend=0;
 
- 		return(0);
 
- 	}
 
- 	if(b->uwrt) {
 
- 		t_runc(a);
 
- 		if (f__nowreading(b))
 
- 			err(a->aerr,errno,"backspace")
 
- 		}
 
- 	f = b->ufd;	/* may have changed in t_runc() */
 
- 	if(b->url>0)
 
- 	{
 
- 		x=FTELL(f);
 
- 		y = x % b->url;
 
- 		if(y == 0) x--;
 
- 		x /= b->url;
 
- 		x *= b->url;
 
- 		(void) FSEEK(f,x,SEEK_SET);
 
- 		return(0);
 
- 	}
 
- 	if(b->ufmt==0)
 
- 	{	FSEEK(f,-(OFF_T)sizeof(uiolen),SEEK_CUR);
 
- 	    if(fread((char *)&n,sizeof(uiolen),1,f));
 
-             return (1);
 
- 		FSEEK(f,-(OFF_T)n-2*sizeof(uiolen),SEEK_CUR);
 
- 		return(0);
 
- 	}
 
- 	w = x = FTELL(f);
 
- 	z = 0;
 
-  loop:
 
- 	while(x) {
 
- 		x -= x < 64 ? x : 64;
 
- 		FSEEK(f,x,SEEK_SET);
 
- 		for(y = x; y < w; y++) {
 
- 			if (getc(f) != '\n')
 
- 				continue;
 
- 			v = FTELL(f);
 
- 			if (v == w) {
 
- 				if (z)
 
- 					goto break2;
 
- 				goto loop;
 
- 				}
 
- 			z = v;
 
- 			}
 
- 		err(a->aerr,(EOF),"backspace")
 
- 		}
 
-  break2:
 
- 	FSEEK(f, z, SEEK_SET);
 
- 	return 0;
 
- }
 
- #ifdef __cplusplus
 
- }
 
- #endif
 
 
  |