home *** CD-ROM | disk | FTP | other *** search
/ The CDPD Public Domain Collection for CDTV 3 / CDPDIII.bin / pd / programming / gnuc / stdio_2 / rcs / refill.c,v < prev    next >
Encoding:
Text File  |  1992-07-04  |  4.0 KB  |  161 lines

  1. head    1.1;
  2. access;
  3. symbols
  4.     version39-41:1.1;
  5. locks;
  6. comment    @ * @;
  7.  
  8.  
  9. 1.1
  10. date    92.06.08.15.10.10;    author mwild;    state Exp;
  11. branches;
  12. next    ;
  13.  
  14.  
  15. desc
  16. @initial checkin
  17. @
  18.  
  19.  
  20. 1.1
  21. log
  22. @Initial revision
  23. @
  24. text
  25. @/*-
  26.  * Copyright (c) 1990 The Regents of the University of California.
  27.  * All rights reserved.
  28.  *
  29.  * This code is derived from software contributed to Berkeley by
  30.  * Chris Torek.
  31.  *
  32.  * Redistribution and use in source and binary forms, with or without
  33.  * modification, are permitted provided that the following conditions
  34.  * are met:
  35.  * 1. Redistributions of source code must retain the above copyright
  36.  *    notice, this list of conditions and the following disclaimer.
  37.  * 2. Redistributions in binary form must reproduce the above copyright
  38.  *    notice, this list of conditions and the following disclaimer in the
  39.  *    documentation and/or other materials provided with the distribution.
  40.  * 3. All advertising materials mentioning features or use of this software
  41.  *    must display the following acknowledgement:
  42.  *    This product includes software developed by the University of
  43.  *    California, Berkeley and its contributors.
  44.  * 4. Neither the name of the University nor the names of its contributors
  45.  *    may be used to endorse or promote products derived from this software
  46.  *    without specific prior written permission.
  47.  *
  48.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  49.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  50.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  51.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  52.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  53.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  54.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  55.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  56.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  57.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  58.  * SUCH DAMAGE.
  59.  */
  60.  
  61. #if defined(LIBC_SCCS) && !defined(lint)
  62. static char sccsid[] = "@@(#)refill.c    5.3 (Berkeley) 2/24/91";
  63. #endif /* LIBC_SCCS and not lint */
  64.  
  65. #define KERNEL
  66. #include "ixemul.h"
  67.  
  68. #include <stdio.h>
  69. #include <stdlib.h>
  70. #include "local.h"
  71.  
  72. static
  73. lflush(fp)
  74.     FILE *fp;
  75. {
  76.  
  77.     if ((fp->_flags & (__SLBF|__SWR)) == __SLBF|__SWR)
  78.         return (__sflush(fp));
  79.     return (0);
  80. }
  81.  
  82. /*
  83.  * Refill a stdio buffer.
  84.  * Return EOF on eof or error, 0 otherwise.
  85.  */
  86. __srefill(fp)
  87.     register FILE *fp;
  88. {
  89.  
  90. #if 0
  91.     /* make sure stdio is set up */
  92.     if (!__sdidinit)
  93.         __sinit();
  94. #endif
  95.  
  96.     if (! fp)
  97.       return EOF;
  98.  
  99.     fp->_r = 0;        /* largely a convenience for callers */
  100.  
  101.     /* SysV does not make this test; take it out for compatibility */
  102.     if (fp->_flags & __SEOF)
  103.         return (EOF);
  104.  
  105.     /* if not already reading, have to be reading and writing */
  106.     if ((fp->_flags & __SRD) == 0) {
  107.         if ((fp->_flags & __SRW) == 0) {
  108.             errno = EBADF;
  109.             return (EOF);
  110.         }
  111.         /* switch to reading */
  112.         if (fp->_flags & __SWR) {
  113.             if (__sflush(fp))
  114.                 return (EOF);
  115.             fp->_flags &= ~__SWR;
  116.             fp->_w = 0;
  117.             fp->_lbfsize = 0;
  118.         }
  119.         fp->_flags |= __SRD;
  120.     } else {
  121.         /*
  122.          * We were reading.  If there is an ungetc buffer,
  123.          * we must have been reading from that.  Drop it,
  124.          * restoring the previous buffer (if any).  If there
  125.          * is anything in that buffer, return.
  126.          */
  127.         if (HASUB(fp)) {
  128.             FREEUB(fp);
  129.             if ((fp->_r = fp->_ur) != 0) {
  130.                 fp->_p = fp->_up;
  131.                 return (0);
  132.             }
  133.         }
  134.     }
  135.  
  136.     if (fp->_bf._base == NULL)
  137.         __smakebuf(fp);
  138.  
  139.     /*
  140.      * Before reading from a line buffered or unbuffered file,
  141.      * flush all line buffered output files, per the ANSI C
  142.      * standard.
  143.      */
  144.     if (fp->_flags & (__SLBF|__SNBF))
  145.         (void) _fwalk(lflush);
  146.     fp->_p = fp->_bf._base;
  147.     fp->_r = (*fp->_read)(fp->_cookie, (char *)fp->_p, fp->_bf._size);
  148.     fp->_flags &= ~__SMOD;    /* buffer contents are again pristine */
  149.     if (fp->_r <= 0) {
  150.         if (fp->_r == 0)
  151.             fp->_flags |= __SEOF;
  152.         else {
  153.             fp->_r = 0;
  154.             fp->_flags |= __SERR;
  155.         }
  156.         return (EOF);
  157.     }
  158.     return (0);
  159. }
  160. @
  161.