2000-02-01 09:37:00 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
2002-01-25 00:16:43 +08:00
|
|
|
ERR_get_error, ERR_peek_error, ERR_peek_last_error,
|
|
|
|
ERR_get_error_line, ERR_peek_error_line, ERR_peek_last_error_line,
|
|
|
|
ERR_get_error_line_data, ERR_peek_error_line_data,
|
2002-11-29 22:21:54 +08:00
|
|
|
ERR_peek_last_error_line_data - obtain error code and data
|
2000-02-01 09:37:00 +08:00
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/err.h>
|
|
|
|
|
|
|
|
unsigned long ERR_get_error(void);
|
|
|
|
unsigned long ERR_peek_error(void);
|
2002-01-25 00:16:43 +08:00
|
|
|
unsigned long ERR_peek_last_error(void);
|
2000-02-01 09:37:00 +08:00
|
|
|
|
|
|
|
unsigned long ERR_get_error_line(const char **file, int *line);
|
|
|
|
unsigned long ERR_peek_error_line(const char **file, int *line);
|
2002-01-25 00:16:43 +08:00
|
|
|
unsigned long ERR_peek_last_error_line(const char **file, int *line);
|
2000-02-01 09:37:00 +08:00
|
|
|
|
|
|
|
unsigned long ERR_get_error_line_data(const char **file, int *line,
|
|
|
|
const char **data, int *flags);
|
|
|
|
unsigned long ERR_peek_error_line_data(const char **file, int *line,
|
|
|
|
const char **data, int *flags);
|
2002-01-25 00:16:43 +08:00
|
|
|
unsigned long ERR_peek_last_error_line_data(const char **file, int *line,
|
|
|
|
const char **data, int *flags);
|
2000-02-01 09:37:00 +08:00
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
2002-01-25 00:16:43 +08:00
|
|
|
ERR_get_error() returns the earliest error code from the thread's error
|
2000-02-01 09:37:00 +08:00
|
|
|
queue and removes the entry. This function can be called repeatedly
|
|
|
|
until there are no more error codes to return.
|
|
|
|
|
2002-01-25 00:16:43 +08:00
|
|
|
ERR_peek_error() returns the earliest error code from the thread's
|
|
|
|
error queue without modifying it.
|
|
|
|
|
|
|
|
ERR_peek_last_error() returns the latest error code from the thread's
|
2000-02-01 09:37:00 +08:00
|
|
|
error queue without modifying it.
|
|
|
|
|
2015-08-18 03:21:33 +08:00
|
|
|
See L<ERR_GET_LIB(3)> for obtaining information about
|
2000-02-01 09:37:00 +08:00
|
|
|
location and reason of the error, and
|
2015-08-18 03:21:33 +08:00
|
|
|
L<ERR_error_string(3)> for human-readable error
|
2000-02-01 09:37:00 +08:00
|
|
|
messages.
|
|
|
|
|
2002-01-25 00:16:43 +08:00
|
|
|
ERR_get_error_line(), ERR_peek_error_line() and
|
|
|
|
ERR_peek_last_error_line() are the same as the above, but they
|
|
|
|
additionally store the file name and line number where
|
2000-02-01 09:37:00 +08:00
|
|
|
the error occurred in *B<file> and *B<line>, unless these are B<NULL>.
|
|
|
|
|
2002-01-25 00:16:43 +08:00
|
|
|
ERR_get_error_line_data(), ERR_peek_error_line_data() and
|
2014-07-02 10:43:42 +08:00
|
|
|
ERR_peek_last_error_line_data() store additional data and flags
|
2002-01-25 00:16:43 +08:00
|
|
|
associated with the error code in *B<data>
|
2000-02-01 09:37:00 +08:00
|
|
|
and *B<flags>, unless these are B<NULL>. *B<data> contains a string
|
2014-07-02 10:43:42 +08:00
|
|
|
if *B<flags>&B<ERR_TXT_STRING> is true.
|
2014-01-29 08:59:35 +08:00
|
|
|
|
|
|
|
An application B<MUST NOT> free the *B<data> pointer (or any other pointers
|
|
|
|
returned by these functions) with OPENSSL_free() as freeing is handled
|
|
|
|
automatically by the error library.
|
2000-02-01 09:37:00 +08:00
|
|
|
|
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
|
|
|
The error code, or 0 if there is no error in the queue.
|
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2015-08-18 03:21:33 +08:00
|
|
|
L<err(3)>, L<ERR_error_string(3)>,
|
|
|
|
L<ERR_GET_LIB(3)>
|
2000-02-01 09:37:00 +08:00
|
|
|
|
|
|
|
=head1 HISTORY
|
|
|
|
|
|
|
|
ERR_get_error(), ERR_peek_error(), ERR_get_error_line() and
|
|
|
|
ERR_peek_error_line() are available in all versions of SSLeay and
|
|
|
|
OpenSSL. ERR_get_error_line_data() and ERR_peek_error_line_data()
|
|
|
|
were added in SSLeay 0.9.0.
|
2002-01-25 00:16:43 +08:00
|
|
|
ERR_peek_last_error(), ERR_peek_last_error_line() and
|
|
|
|
ERR_peek_last_error_line_data() were added in OpenSSL 0.9.7.
|
2000-02-01 09:37:00 +08:00
|
|
|
|
|
|
|
=cut
|