aboutsummaryrefslogtreecommitdiff
path: root/sys/libc/cread.c
blob: 8cc727a5b51546e9431a59c915254731cbadcb76 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/* Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.
*/

#define import_spp
#define	import_libc
#define	import_xnames
#define import_stdio
#define import_error
#define import_fset
#include <iraf.h>


/* C_READ -- FIO read from a file.  Read up to maxbytes bytes from the stream
** fd into the buffer buf.  If the device associated with file fd is a record
** structured device a single record is read, and the byte count will generally
** be less than the maximum.  If the physical record was larger than maxbytes
** the remainder of the record is returned in successive reads.  If the actual
** file is a text file FIO XCHARs are returned as C chars.  If the actual file
** is a binary file no conversion is performed, and an integral number of XCHARs
** are read.
**
** For reasons of consistency with SPP usage, EOF is returned when end of file
** is reached (fread returns 0), and an error action is taken if a file read
** error occurs.  We cannot return ERR when an error occurs since ERR and EOF
** have the same value in STDIO land.  IFERR may be used to catch file read
** errors.
*/
int
c_read (
  XINT	fd,			/* FIO file descriptor		*/
  char	*buf,			/* output buffer		*/
  int	maxbytes		/* max bytes to read		*/
)
{
	XINT  x_fd = fd;
	int   nchars_read;


	if (c_fstati (fd, F_TYPE) == TEXT_FILE) {
	    register char	*op = buf;
	    register int	ch, n = maxbytes;
	    register FILE	*fp = FDTOFP(fd);

	    while (--n >= 0 && (ch = getc(fp)) >= 0) {
		*op++ = ch;
		if (ch == '\n')
		    break;
	    }
	    if (ferror (fp))
		c_erract (EA_ERROR);
	    if (!(nchars_read = op - buf))
		nchars_read = XEOF;

	} else {
	    XINT	x_maxchars = maxbytes / sizeof(XCHAR);
	    XCHAR	*bp = (XCHAR *)buf;

	    /* Verify that the pointer coercion char->XCHAR->char is legal,
	     * i.e., that the char pointer is aligned to an XCHAR word
	     * boundary if required on this machine.
	     */
	    if (buf != (char *)bp)
		c_error (1, "c_read: buffer not xchar aligned");
	    
	    if ((nchars_read = READ (&x_fd, bp, &x_maxchars)) > 0)
		nchars_read *= sizeof(XCHAR);
	}

	return (nchars_read == XEOF ? EOF : nchars_read);
}