 7c4cd0e6b0
			
		
	
	
		7c4cd0e6b0
		
	
	
	
	
		
			
			- split sprintf() and snprintf() to solve a linking problem when compiling an application
		
			
				
	
	
		
			102 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
| .\" Copyright (c) 1980 Regents of the University of California.
 | |
| .\" All rights reserved.  The Berkeley software License Agreement
 | |
| .\" specifies the terms and conditions for redistribution.
 | |
| .\"
 | |
| .\"	@(#)read.2	6.6 (Berkeley) 5/23/86
 | |
| .\"
 | |
| .TH READ 2 "May 23, 1986"
 | |
| .UC 4
 | |
| .SH NAME
 | |
| read, pread \- read input
 | |
| .SH SYNOPSIS
 | |
| .nf
 | |
| .ft B
 | |
| #include <sys/types.h>
 | |
| #include <unistd.h>
 | |
| 
 | |
| ssize_t read(int \fId\fP, void *\fIbuf\fP, size_t \fInbytes\fP)
 | |
| ssize_t pread(int \fId\fP, void *\fIbuf\fP, size_t \fInbytes\fP, off_t \fIoffset\fP)
 | |
| .fi
 | |
| .SH DESCRIPTION
 | |
| .B Read
 | |
| attempts to read
 | |
| .I nbytes
 | |
| of data from the object referenced by the descriptor
 | |
| .I d
 | |
| into the buffer pointed to by
 | |
| .IR buf .
 | |
| .PP
 | |
| On objects capable of seeking, the
 | |
| .B read
 | |
| starts at a position
 | |
| given by the pointer associated with
 | |
| .IR d 
 | |
| (see
 | |
| .BR lseek (2)).
 | |
| Upon return from
 | |
| .BR read ,
 | |
| the pointer is incremented by the number of bytes actually read.
 | |
| .PP
 | |
| Objects that are not capable of seeking always read from the current
 | |
| position.  The value of the pointer associated with such an
 | |
| object is undefined.
 | |
| .PP
 | |
| Upon successful completion,
 | |
| .B read
 | |
| return the number of bytes actually read and placed in the buffer.
 | |
| The system guarantees to read the number of bytes requested if
 | |
| the descriptor references a normal file that has that many bytes left
 | |
| before the end-of-file, but in no other case.
 | |
| .PP
 | |
| If the returned value is 0, then
 | |
| end-of-file has been reached.
 | |
| .PP
 | |
| The
 | |
| .B pread
 | |
| system call performs the same functions, but reads from the specified
 | |
| position in the file without modifying the file pointer.
 | |
| .SH "RETURN VALUE
 | |
| If successful, the
 | |
| number of bytes actually read is returned.
 | |
| Otherwise, a \-1 is returned and the global variable
 | |
| .B errno
 | |
| is set to indicate the error.
 | |
| .SH "ERRORS
 | |
| .B Read
 | |
| and 
 | |
| .B pread
 | |
| will fail if one or more of the following are true:
 | |
| .TP 15
 | |
| [EBADF]
 | |
| \fID\fP is not a valid descriptor open for reading.
 | |
| .TP 15
 | |
| [EFAULT]
 | |
| \fIBuf\fP points outside the allocated address space.
 | |
| .TP 15
 | |
| [EIO]
 | |
| An I/O error occurred while reading from the file system.
 | |
| .TP 15
 | |
| [EINTR]
 | |
| A read from a slow device was interrupted before
 | |
| any data arrived by the delivery of a signal.
 | |
| .TP 15
 | |
| [EAGAIN]
 | |
| The file was marked for non-blocking I/O,
 | |
| and no data were ready to be read.
 | |
| .PP
 | |
| The
 | |
| .B pread
 | |
| system call may also return any of the
 | |
| .B lseek
 | |
| errors.
 | |
| .SH "SEE ALSO"
 | |
| .BR dup (2),
 | |
| .BR fcntl (2),
 | |
| .BR open (2),
 | |
| .BR pipe (2),
 | |
| .BR lseek (2),
 | |
| .BR write (2).
 | |
| .SH NOTES
 | |
| .B pread
 | |
| is currently implemented as a library function instead of a system call.
 |