libexplain  1.4.D001
Functions
libexplain/buffer/errno/read.c File Reference
#include <libexplain/ac/errno.h>
#include <libexplain/ac/fcntl.h>
#include <libexplain/ac/sys/ioctl.h>
#include <libexplain/ac/sys/mtio.h>
#include <libexplain/ac/sys/stat.h>
#include <libexplain/ac/unistd.h>
#include <libexplain/buffer/ebadf.h>
#include <libexplain/buffer/efault.h>
#include <libexplain/buffer/eio.h>
#include <libexplain/buffer/eintr.h>
#include <libexplain/buffer/errno/generic.h>
#include <libexplain/buffer/errno/read.h>
#include <libexplain/buffer/fildes.h>
#include <libexplain/buffer/gettext.h>
#include <libexplain/buffer/mount_point.h>
#include <libexplain/buffer/pointer.h>
#include <libexplain/buffer/size_t.h>
#include <libexplain/explanation.h>
#include <libexplain/is_same_inode.h>
#include <libexplain/string_buffer.h>

Go to the source code of this file.

Functions

static void explain_buffer_errno_read_system_call (explain_string_buffer_t *sb, int errnum, int fildes, const void *data, size_t data_size)
static int is_a_tape (int fildes)
void explain_buffer_errno_read_explanation (explain_string_buffer_t *sb, int errnum, const char *syscall_name, int fildes, const void *data, size_t data_size)
void explain_buffer_errno_read (explain_string_buffer_t *sb, int errnum, int fildes, const void *data, size_t data_size)

Function Documentation

void explain_buffer_errno_read ( explain_string_buffer_t sb,
int  errnum,
int  fildes,
const void *  data,
size_t  data_size 
)

The explain_buffer_errno_lseek_explanation function is called by the explain_buffer_errno_lseek function (and others) to print the explanation, the part after "because..."

Parameters:
sbThe string buffer into which the message is to be written.
errnumThe error value to be decoded, usually obtain from the errno global variable just before this function is called. This is necessary if you need to call any code between the system call to be explained and this function, because many libc functions will alter the value of errno.
fildesThe file descriptor to be read from, exactly as passed to the read(2) system call.
dataThe address of the base address in memory to write the data (the original read call modified the data, this function will not), exactly as passed to the read(2) system call.
data_sizeThe maximum number of bytes of data to be read, exactly as passed to the read(2) system call.
Note:
Given a suitably thread safe buffer, this function is thread safe.

Definition at line 307 of file read.c.

void explain_buffer_errno_read_explanation ( explain_string_buffer_t sb,
int  errnum,
const char *  syscall_name,
int  fildes,
const void *  data,
size_t  data_size 
)

The explain_buffer_errno_read_explanation function is called by the explain_buffer_errno_read function (and others) to print the explanation, the part after "because..."

Parameters:
sbThe string buffer into which the message is to be written.
errnumThe error value to be decoded, usually obtain from the errno global variable just before this function is called. This is necessary if you need to call any code between the system call to be explained and this function, because many libc functions will alter the value of errno.
syscall_nameThe name of the offending system call.
fildesThe file descriptor to be read from, exactly as passed to the read(2) system call.
dataThe address of the base address in memory to write the data (the original read call modified the data, this function will not), exactly as passed to the read(2) system call.
data_sizeThe maximum number of bytes of data to be read, exactly as passed to the read(2) system call.
Note:
Given a suitably thread safe buffer, this function is thread safe.

Definition at line 70 of file read.c.

static void explain_buffer_errno_read_system_call ( explain_string_buffer_t sb,
int  errnum,
int  fildes,
const void *  data,
size_t  data_size 
) [static]

Definition at line 44 of file read.c.

static int is_a_tape ( int  fildes) [static]

Definition at line 59 of file read.c.