1 /* $Id: dfe.c,v 1.1.1.1 2008/08/24 05:34:47 gmcgarry Exp $ */
3 * Copyright(C) Caldera International Inc. 2001-2002. All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
9 * Redistributions of source code and documentation must retain the above
10 * copyright notice, this list of conditions and the following disclaimer.
11 * Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditionsand the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * All advertising materials mentioning features or use of this software
15 * must display the following acknowledgement:
16 * This product includes software developed or owned by Caldera
18 * Neither the name of Caldera International, Inc. nor the names of other
19 * contributors may be used to endorse or promote products derived from
20 * this software without specific prior written permission.
22 * USE OF THE SOFTWARE PROVIDED FOR UNDER THIS LICENSE BY CALDERA
23 * INTERNATIONAL, INC. AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR
24 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
25 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26 * DISCLAIMED. IN NO EVENT SHALL CALDERA INTERNATIONAL, INC. BE LIABLE
27 * FOR ANY DIRECT, INDIRECT INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 * HOWEVER CAUSED AND ON ANY THEORY OFLIABILITY, WHETHER IN CONTRACT,
31 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
32 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33 * POSSIBILITY OF SUCH DAMAGE.
37 static int y_getc(void), y_putc(int), y_rev(void), y_err(void);
38 static int c_dfe(cilist
*a
, int flag
);
45 if((n
=c_dfe(a
,READ
)))return(n
);
47 if(curunit
->uwrt
) nowreading(curunit
);
51 dorevert
= donewrec
= y_err
;
54 err(a
->cierr
,100,"startio");
64 if((n
=c_dfe(a
,WRITE
))) return(n
);
66 if(!curunit
->uwrt
) nowwriting(curunit
);
70 dorevert
= donewrec
= y_err
;
73 err(a
->cierr
,100,"startwrt");
93 c_dfe(cilist
*a
, int flag
)
98 cursor
=scale
=recpos
=0;
99 if(a
->ciunit
>MXUNIT
|| a
->ciunit
<0)
100 err(a
->cierr
,101,"startchk");
101 curunit
= &units
[a
->ciunit
];
102 if(curunit
->ufd
==NULL
&& fk_open(flag
,DIR,FMT
,a
->ciunit
))
103 err(a
->cierr
,104,"dfe");
105 if(!curunit
->ufmt
) err(a
->cierr
,102,"dfe")
106 if(!curunit
->useek
) err(a
->cierr
,104,"dfe")
108 fseek(cf
,(long)curunit
->url
* (a
->cirec
-1),0);
117 if(curunit
->uend
) return(-1);
118 if((ch
=getc(cf
))!=EOF
)
121 if(curunit
->url
>=recpos
||
132 err(elist
->cierr
,errno
,"readingd");
139 if(recpos
<= curunit
->url
|| curunit
->url
==1)
142 err(elist
->cierr
,110,"dout");
148 { /*what about work done?*/
149 if(curunit
->url
==1 || recpos
==curunit
->url
)
151 while(recpos
<curunit
->url
)
160 err(elist
->cierr
, 110, "dfe");