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,
|
2019-09-05 04:04:08 +08:00
|
|
|
ERR_get_error_func, ERR_peek_error_func, ERR_peek_last_error_func,
|
|
|
|
ERR_get_error_data, ERR_peek_error_data, ERR_peek_last_error_data,
|
|
|
|
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_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
|
|
|
|
2019-09-05 04:04:08 +08:00
|
|
|
unsigned long ERR_get_error_func(const char **func);
|
|
|
|
unsigned long ERR_peek_error_func(const char **func);
|
|
|
|
unsigned long ERR_peek_last_error_func(const char **func);
|
|
|
|
|
|
|
|
unsigned long ERR_get_error_data(const char **data, int *flags);
|
|
|
|
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,
|
|
|
|
const char *func,
|
|
|
|
const char **data, int *flags);
|
|
|
|
unsigned long ERR_peek_error_all(const char **file, int *line,
|
|
|
|
const char *func,
|
|
|
|
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);
|
|
|
|
|
|
|
|
Deprecated since OpenSSL 3.0:
|
|
|
|
|
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
|
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.
|
|
|
|
|
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
|
|
|
|
2002-01-25 00:16:43 +08:00
|
|
|
ERR_get_error_line(), ERR_peek_error_line() and
|
2019-09-05 04:04:08 +08:00
|
|
|
ERR_peek_last_error_line() are the same as ERR_get_error(),
|
2019-09-19 21:02:50 +08:00
|
|
|
ERR_peek_error() and ERR_peek_last_error(), but on success they
|
2019-09-28 01:17:09 +08:00
|
|
|
additionally store the filename and line number where
|
2019-09-19 21:02:50 +08:00
|
|
|
the error occurred in *B<file> and *B<line>, as far as they are not B<NULL>.
|
2019-09-28 01:17:09 +08:00
|
|
|
An unset filename is indicated as B<"">, i.e., an empty string.
|
2019-09-19 21:02:50 +08:00
|
|
|
An unset line number is indicated as B<0>.
|
|
|
|
|
|
|
|
A pointer returned this way by these functions and the ones below
|
|
|
|
is valid until the respective entry is removed from the error queue.
|
2000-02-01 09:37:00 +08:00
|
|
|
|
2019-09-05 04:04:08 +08:00
|
|
|
ERR_get_error_func(), ERR_peek_error_func() and
|
|
|
|
ERR_peek_last_error_func() are the same as ERR_get_error(),
|
2019-09-19 21:02:50 +08:00
|
|
|
ERR_peek_error() and ERR_peek_last_error(), but on success they
|
|
|
|
additionally store the name of the function where the error occurred
|
|
|
|
in *B<func>, unless it is B<NULL>.
|
|
|
|
An unset function name is indicated as B<"">.
|
2019-09-05 04:04:08 +08:00
|
|
|
|
|
|
|
ERR_get_error_data(), ERR_peek_error_data() and
|
|
|
|
ERR_peek_last_error_data() are the same as ERR_get_error(),
|
2019-09-19 21:02:50 +08:00
|
|
|
ERR_peek_error() and ERR_peek_last_error(), but on success they
|
2019-09-05 04:04:08 +08:00
|
|
|
additionally store additional data and flags associated with the error
|
2019-09-19 21:02:50 +08:00
|
|
|
code in *B<data> and *B<flags>, as far as they are not B<NULL>.
|
|
|
|
Unset data is indicated as B<"">.
|
|
|
|
In this case the value given for the flag is irrelevant (and equals B<0>).
|
2019-09-05 04:04:08 +08:00
|
|
|
*B<data> contains a string if *B<flags>&B<ERR_TXT_STRING> is true.
|
|
|
|
|
|
|
|
ERR_get_error_all(), ERR_peek_error_all() and
|
|
|
|
ERR_peek_last_error_all() are combinations of all of the above.
|
|
|
|
|
2002-01-25 00:16:43 +08:00
|
|
|
ERR_get_error_line_data(), ERR_peek_error_line_data() and
|
2019-09-05 04:04:08 +08:00
|
|
|
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 should no longer
|
|
|
|
be used.
|
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
|
|
|
|
|
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
|
|
|
|
|
|
|
|
ERR_get_error_func(), ERR_peek_error_func(), ERR_peek_last_error_func(),
|
|
|
|
ERR_get_error_data(), ERR_peek_error_data(), ERR_peek_last_error_data(),
|
|
|
|
ERR_get_error_all(), ERR_peek_error_all() and ERR_peek_last_error_all()
|
|
|
|
were added in OpenSSL 3.0.
|
|
|
|
|
|
|
|
ERR_get_error_line_data(), ERR_peek_error_line_data() and
|
|
|
|
ERR_peek_last_error_line_data() became deprecated in OpenSSL 3.0.
|
|
|
|
|
|
|
|
|
2016-05-18 23:44:05 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2017-03-02 23:07:21 +08:00
|
|
|
Copyright 2000-2017 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
|