Annotation of 43BSDReno/lib/libI77/rdfe.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1980 Regents of the University of California.
                      3:  * All rights reserved.  The Berkeley software License Agreement
                      4:  * specifies the terms and conditions for redistribution.
                      5:  *
                      6:  *     @(#)rdfe.c      5.1     6/7/85
                      7:  */
                      8: 
                      9: /*
                     10:  * read direct formatted external i/o
                     11:  */
                     12: 
                     13: #include "fio.h"
                     14: 
                     15: extern int rd_ed(),rd_ned();
                     16: int y_getc(),y_rnew(),y_tab();
                     17: 
                     18: LOCAL char rdfe[] = "read dfe";
                     19: 
                     20: s_rdfe(a) cilist *a;
                     21: {
                     22:        int n;
                     23:        reading = YES;
                     24:        if(n=c_dfe(a,READ,rdfe)) return(n);
                     25:        if(curunit->uwrt && ! nowreading(curunit)) err(errflag, errno, rdfe)
                     26:        getn = y_getc;
                     27:        doed = rd_ed;
                     28:        doned = rd_ned;
                     29:        dotab = y_tab;
                     30:        dorevert = doend = donewrec = y_rnew;
                     31:        if(pars_f()) err(errflag,F_ERFMT,rdfe)
                     32:        fmt_bg();
                     33:        return(OK);
                     34: }
                     35: 
                     36: e_rdfe()
                     37: {
                     38:        en_fio();
                     39:        return(OK);
                     40: }
                     41: 
                     42: LOCAL
                     43: y_getc()
                     44: {
                     45:        int ch;
                     46:        if(curunit->uend) return(EOF);
                     47:        if(curunit->url==1 || recpos++ < curunit->url)
                     48:        {
                     49:                if((ch=getc(cf))!=EOF)
                     50:                {
                     51:                                return(ch);
                     52:                }
                     53:                if(feof(cf))
                     54:                {
                     55:                        curunit->uend = YES;
                     56:                        return(EOF);
                     57:                }
                     58:                err(errflag,errno,rdfe);
                     59:        }
                     60:        else return(' ');
                     61: }
                     62: 
                     63: /*
                     64: /*y_rev()
                     65: /*{    /*what about work done?*/
                     66: /*     if(curunit->url==1) return(0);
                     67: /*     while(recpos<curunit->url) (*putn)(' ');
                     68: /*     recpos=0;
                     69: /*     return(0);
                     70: /*}
                     71: /*
                     72: /*y_err()
                     73: /*{
                     74: /*     err(errflag, F_EREREC, rdfe+5);
                     75: /*}
                     76: */
                     77: 
                     78: LOCAL
                     79: y_rnew()
                     80: {      if(curunit->url != 1)
                     81:        {       fseek(cf,(long)curunit->url*(++recnum),0);
                     82:                recpos = reclen = cursor = 0;
                     83:        }
                     84:        return(OK);
                     85: }

unix.superglobalmegacorp.com

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