explain_lseek(3) | Library Functions Manual | explain_lseek(3) |
explain_lseek - explain lseek(2) errors
#include <libexplain/lseek.h>
const char *explain_lseek(int fildes, long long offset, int whence);
const char *explain_errno_lseek(int errnum, int fildes, long long offset, int
whence);
void explain_message_lseek(char *message, int message_size, int fildes, long
long offset, int whence);
void explain_message_errno_lseek(char *message, int message_size, int errnum,
int fildes, long long offset, int whence);
These functions may be used to obtain explanations for lseek(2) errors.
const char *explain_lseek(int fildes, long long offset, int whence);
The explain_lseek function may be used to obtain a human readable explanation of what went wrong in an lseek(2) system call. The least the message will contain is the value of strerror(errno), but usually it will do much better, and indicate the underlying cause in more detail.
The errno global variable will be used to obtain the error value to be decoded.
This function is intended to be used in a fashion similar to the following example:
if (lseek(fd, offset, whence) == (off_t)-1) {
fprintf(stderr, '%s0, explain_lseek(fd, offset, whence);
exit(EXIT_FAILURE); }
Note: This function is not thread safe, because it shares a return buffer across all threads, and many other functions in this library.
const char *explain_errno_lseek(int errnum, int fildes, long long offset, int whence);
The explain_errno_lseek function may be used to obtain a human readable explanation of what went wrong in an lseek(2) system call. The least the message will contain is the value of strerror(errnum), but usually it will do much better, and indicate the underlying cause in more detail.
This function is intended to be used in a fashion similar to the following example:
if (lseek(fd, offset, whence) == (off_t)-1) {
int errnum = errno;
fprintf(stderr, '%s0, explain_errno_lseek(fd, eernum, offset,
whence);
exit(EXIT_FAILURE); }
Note: This function is not thread safe, because it shares a return buffer across all threads, and many other functions in this library.
void explain_message_lseek(char *message, int message_size, int fildes, long long offset, int whence);
The explain_message_lseek function may be used to obtain a human readable explanation of what went wrong in an lseek(2) system call. The least the message will contain is the value of strerror(errno), but usually it will do much better, and indicate the underlying cause in more detail.
The errno global variable will be used to obtain the error value to be decoded.
This function is intended to be used in a fashion similar to the following example:
if (lseek(fd, offset, whence) == (off_t)-1) {
char message[3000];
explain_message_lseek(message, sizeof(message), fd, offset, whence);
fprintf(stderr, '%s0, message);
exit(EXIT_FAILURE); }
void explain_message_errno_lseek(char *message, int message_size, int errnum, int fildes, long long offset, int whence);
The explain_message_errno_lseek function may be used to obtain a human readable explanation of what went wrong in an lseek(2) system call. The least the message will contain is the value of strerror(errnum), but usually it will do much better, and indicate the underlying cause in more detail.
This function is intended to be used in a fashion similar to the following example:
if (lseek(fd, offset, whence) == (off_t)-1) {
char message[3000];
int errnum = errno;
explain_message_errno_lseek(message, sizeof(message), errnum, fd,
offset, whence);
fprintf(stderr, '%s0, message);
exit(EXIT_FAILURE); }
libexplain version 1.4
Copyright (C) 2008 Peter Miller
Written by Peter Miller <pmiller@opensource.org.au>