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,
|
2020-11-21 05:13:11 +08:00
|
|
|
ERR_peek_error_func, ERR_peek_last_error_func,
|
|
|
|
ERR_peek_error_data, ERR_peek_last_error_data,
|
2019-09-05 04:04:08 +08:00
|
|
|
ERR_get_error_all, ERR_peek_error_all, ERR_peek_last_error_all,
|
|
|
|
ERR_get_error_line_data, ERR_peek_error_line_data, 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_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
|
|
|
|
2019-09-05 04:04:08 +08:00
|
|
|
unsigned long ERR_peek_error_func(const char **func);
|
|
|
|
unsigned long ERR_peek_last_error_func(const char **func);
|
|
|
|
|
|
|
|
unsigned long ERR_peek_error_data(const char **data, int *flags);
|
|
|
|
unsigned long ERR_peek_last_error_data(const char **data, int *flags);
|
|
|
|
|
|
|
|
unsigned long ERR_get_error_all(const char **file, int *line,
|
2020-11-21 05:13:11 +08:00
|
|
|
const char **func,
|
2019-09-05 04:04:08 +08:00
|
|
|
const char **data, int *flags);
|
|
|
|
unsigned long ERR_peek_error_all(const char **file, int *line,
|
2022-01-15 09:38:41 +08:00
|
|
|
const char **func,
|
2019-09-05 04:04:08 +08:00
|
|
|
const char **data, int *flags);
|
|
|
|
unsigned long ERR_peek_last_error_all(const char **file, int *line,
|
|
|
|
const char *func,
|
|
|
|
const char **data, int *flags);
|
|
|
|
|
2021-12-02 19:33:49 +08:00
|
|
|
The following functions have been deprecated since OpenSSL 3.0, and can be
|
|
|
|
hidden entirely by defining B<OPENSSL_API_COMPAT> with a suitable version value,
|
|
|
|
see L<openssl_user_macros(7)>:
|
2019-09-05 04:04:08 +08:00
|
|
|
|
2020-11-21 05:13:11 +08:00
|
|
|
unsigned long ERR_get_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,
|
2017-01-21 02:58:49 +08:00
|
|
|
const char **data, int *flags);
|
2000-02-01 09:37:00 +08:00
|
|
|
unsigned long ERR_peek_error_line_data(const char **file, int *line,
|
2017-01-21 02:58:49 +08:00
|
|
|
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,
|
2017-01-21 02:58:49 +08:00
|
|
|
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
|
2020-11-21 05:13:11 +08:00
|
|
|
queue and removes the entry. This function can be called repeatedly
|
2000-02-01 09:37:00 +08:00
|
|
|
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.
|
|
|
|
|
2019-09-19 21:02:50 +08:00
|
|
|
See L<ERR_GET_LIB(3)> for obtaining further specific information
|
|
|
|
such as the reason of the error,
|
|
|
|
and L<ERR_error_string(3)> for human-readable error messages.
|
2000-02-01 09:37:00 +08:00
|
|
|
|
2020-11-21 05:13:11 +08:00
|
|
|
ERR_get_error_all() is the same as ERR_get_error(), but on success it
|
|
|
|
additionally stores the filename, line number and function where the error
|
|
|
|
occurred in *I<file>, *I<line> and *I<func>, and also extra text and flags
|
|
|
|
in *I<data>, *I<flags>. If any of those parameters are NULL, it will not
|
|
|
|
be changed.
|
|
|
|
An unset filename is indicated as "", i.e. an empty string.
|
|
|
|
An unset line number is indicated as 0.
|
|
|
|
An unset function name is indicated as "", i.e. an empty string.
|
2019-09-19 21:02:50 +08:00
|
|
|
|
|
|
|
A pointer returned this way by these functions and the ones below
|
2020-11-21 05:13:11 +08:00
|
|
|
is valid until the respective entry is overwritten in the error queue.
|
|
|
|
|
|
|
|
ERR_peek_error_line() and ERR_peek_last_error_line() are the same as
|
|
|
|
ERR_peek_error() and ERR_peek_last_error(), but on success they additionally
|
|
|
|
store the filename and line number where the error occurred in *I<file> and
|
2021-09-21 08:59:56 +08:00
|
|
|
*I<line>, as far as they are not NULL.
|
2020-11-21 05:13:11 +08:00
|
|
|
An unset filename is indicated as "", i.e., an empty string.
|
|
|
|
An unset line number is indicated as 0.
|
|
|
|
|
|
|
|
ERR_peek_error_func() and ERR_peek_last_error_func() are the same as
|
|
|
|
ERR_peek_error() and ERR_peek_last_error(), but on success they additionally
|
|
|
|
store the name of the function where the error occurred in *I<func>, unless
|
2021-09-21 08:59:56 +08:00
|
|
|
it is NULL.
|
2020-11-21 05:13:11 +08:00
|
|
|
An unset function name is indicated as "".
|
|
|
|
|
|
|
|
ERR_peek_error_data() and ERR_peek_last_error_data() are the same as
|
|
|
|
ERR_peek_error() and ERR_peek_last_error(), but on success they additionally
|
|
|
|
store additional data and flags associated with the error code in *I<data>
|
|
|
|
and *I<flags>, as far as they are not NULL.
|
|
|
|
Unset data is indicated as "".
|
|
|
|
In this case the value given for the flag is irrelevant (and equals 0).
|
|
|
|
*I<data> contains a string if *I<flags>&B<ERR_TXT_STRING> is true.
|
|
|
|
|
|
|
|
ERR_peek_error_all() and ERR_peek_last_error_all() are combinations of all
|
|
|
|
of the above.
|
|
|
|
|
|
|
|
ERR_get_error_line(), ERR_get_error_line_data(), ERR_peek_error_line_data()
|
|
|
|
and ERR_peek_last_error_line_data() are older variants of ERR_get_error_all(),
|
|
|
|
ERR_peek_error_all() and ERR_peek_last_error_all(), and may give confusing
|
|
|
|
results. They should no longer be used and are therefore deprecated.
|
|
|
|
|
|
|
|
An application B<MUST NOT> free the *I<data> pointer (or any other pointers
|
2014-01-29 08:59:35 +08:00
|
|
|
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
|
|
|
|
|
2017-03-02 23:07:21 +08:00
|
|
|
L<ERR_error_string(3)>,
|
2015-08-18 03:21:33 +08:00
|
|
|
L<ERR_GET_LIB(3)>
|
2000-02-01 09:37:00 +08:00
|
|
|
|
2019-09-05 04:04:08 +08:00
|
|
|
=head1 HISTORY
|
|
|
|
|
2020-11-21 05:13:11 +08:00
|
|
|
ERR_peek_error_func(), ERR_peek_last_error_func(),
|
|
|
|
ERR_peek_error_data(), ERR_peek_last_error_data(),
|
|
|
|
ERR_peek_error_all() and ERR_peek_last_error_all()
|
2019-09-05 04:04:08 +08:00
|
|
|
were added in OpenSSL 3.0.
|
|
|
|
|
2020-11-21 05:13:11 +08:00
|
|
|
ERR_get_error_line(), ERR_get_error_line_data(), ERR_peek_error_line_data()
|
|
|
|
and ERR_peek_last_error_line_data() became deprecated in OpenSSL 3.0.
|
2019-09-05 04:04:08 +08:00
|
|
|
|
|
|
|
|
2016-05-18 23:44:05 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2022-05-03 18:52:38 +08:00
|
|
|
Copyright 2000-2022 The OpenSSL Project Authors. All Rights Reserved.
|
2016-05-18 23:44:05 +08:00
|
|
|
|
2018-12-06 21:04:44 +08:00
|
|
|
Licensed under the Apache License 2.0 (the "License"). You may not use
|
2016-05-18 23:44:05 +08:00
|
|
|
this file except in compliance with the License. You can obtain a copy
|
|
|
|
in the file LICENSE in the source distribution or at
|
|
|
|
L<https://www.openssl.org/source/license.html>.
|
|
|
|
|
|
|
|
=cut
|