blob: ae6ee5e8147d9c2af1dbf5745986f699a52cba5c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
/*
* util.c
*
* Copyright (C) AB Strakt 2001, All rights reserved
* Copyright (C) Jean-Paul Calderone 2009, All rights reserved
*
* Utility functions.
* See the file RATIONALE for a short explanation of why this module was written.
*
* Reviewed 2001-07-23
*/
#include <Python.h>
#include "util.h"
/*
* Flush OpenSSL's error queue and return a list of errors (a (library,
* function, reason) string tuple)
*
* Arguments: None
* Returns: A list of errors (new reference)
*/
PyObject *
error_queue_to_list(void) {
PyObject *errlist, *tuple;
long err;
errlist = PyList_New(0);
while ((err = ERR_get_error()) != 0) {
tuple = Py_BuildValue("(sss)", ERR_lib_error_string(err),
ERR_func_error_string(err),
ERR_reason_error_string(err));
PyList_Append(errlist, tuple);
Py_DECREF(tuple);
}
return errlist;
}
void exception_from_error_queue(PyObject *the_Error) {
PyObject *errlist = error_queue_to_list();
PyErr_SetObject(the_Error, errlist);
Py_DECREF(errlist);
}
/*
* Flush OpenSSL's error queue and ignore the result
*
* Arguments: None
* Returns: None
*/
void
flush_error_queue(void) {
/*
* Make sure to save the errors to a local. Py_DECREF might expand such
* that it evaluates its argument more than once, which would lead to
* very nasty things if we just invoked it with error_queue_to_list().
*/
PyObject *list = error_queue_to_list();
Py_DECREF(list);
}
|