mirror of
				https://github.com/psycopg/psycopg2.git
				synced 2025-10-26 05:21:03 +03:00 
			
		
		
		
	Further modeling of exception raising
This commit is contained in:
		
							parent
							
								
									d93732558d
								
							
						
					
					
						commit
						31812c01e6
					
				|  | @ -35,7 +35,7 @@ | ||||||
| 
 | 
 | ||||||
| /* qstring_quote - do the quote process on plain and unicode strings */ | /* qstring_quote - do the quote process on plain and unicode strings */ | ||||||
| 
 | 
 | ||||||
| static PyObject * | BORROWED static PyObject * | ||||||
| qstring_quote(qstringObject *self) | qstring_quote(qstringObject *self) | ||||||
| { | { | ||||||
|     PyObject *str; |     PyObject *str; | ||||||
|  |  | ||||||
|  | @ -51,19 +51,19 @@ typedef struct { | ||||||
| 
 | 
 | ||||||
| /* functions exported from lobject_int.c */ | /* functions exported from lobject_int.c */ | ||||||
| 
 | 
 | ||||||
| HIDDEN int lobject_open(lobjectObject *self, connectionObject *conn, | RAISES_NEG HIDDEN int lobject_open(lobjectObject *self, connectionObject *conn, | ||||||
|                                    Oid oid, const char *smode, Oid new_oid, |                                    Oid oid, const char *smode, Oid new_oid, | ||||||
|                                    const char *new_file); |                                    const char *new_file); | ||||||
| HIDDEN int lobject_unlink(lobjectObject *self); | RAISES_NEG HIDDEN int lobject_unlink(lobjectObject *self); | ||||||
| HIDDEN int lobject_export(lobjectObject *self, const char *filename); | RAISES_NEG HIDDEN int lobject_export(lobjectObject *self, const char *filename); | ||||||
| 
 | 
 | ||||||
| HIDDEN Py_ssize_t lobject_read(lobjectObject *self, char *buf, size_t len); | RAISES_NEG HIDDEN Py_ssize_t lobject_read(lobjectObject *self, char *buf, size_t len); | ||||||
| HIDDEN Py_ssize_t lobject_write(lobjectObject *self, const char *buf, | RAISES_NEG HIDDEN Py_ssize_t lobject_write(lobjectObject *self, const char *buf, | ||||||
|                                 size_t len); |                                 size_t len); | ||||||
| HIDDEN int lobject_seek(lobjectObject *self, int pos, int whence); | RAISES_NEG HIDDEN int lobject_seek(lobjectObject *self, int pos, int whence); | ||||||
| HIDDEN int lobject_tell(lobjectObject *self); | RAISES_NEG HIDDEN int lobject_tell(lobjectObject *self); | ||||||
| HIDDEN int lobject_truncate(lobjectObject *self, size_t len); | RAISES_NEG HIDDEN int lobject_truncate(lobjectObject *self, size_t len); | ||||||
| HIDDEN int lobject_close(lobjectObject *self); | RAISES_NEG HIDDEN int lobject_close(lobjectObject *self); | ||||||
| 
 | 
 | ||||||
| #define lobject_is_closed(self) \ | #define lobject_is_closed(self) \ | ||||||
|     ((self)->fd < 0 || !(self)->conn || (self)->conn->closed) |     ((self)->fd < 0 || !(self)->conn || (self)->conn->closed) | ||||||
|  |  | ||||||
|  | @ -50,7 +50,7 @@ collect_error(connectionObject *conn, char **error) | ||||||
|  * |  * | ||||||
|  * Valid mode are [r|w|rw|n][t|b] |  * Valid mode are [r|w|rw|n][t|b] | ||||||
|  */ |  */ | ||||||
| static int | RAISES_NEG static int | ||||||
| _lobject_parse_mode(const char *mode) | _lobject_parse_mode(const char *mode) | ||||||
| { | { | ||||||
|     int rv = 0; |     int rv = 0; | ||||||
|  | @ -147,7 +147,7 @@ _lobject_unparse_mode(int mode) | ||||||
| 
 | 
 | ||||||
| /* lobject_open - create a new/open an existing lo */ | /* lobject_open - create a new/open an existing lo */ | ||||||
| 
 | 
 | ||||||
| int | RAISES_NEG int | ||||||
| lobject_open(lobjectObject *self, connectionObject *conn, | lobject_open(lobjectObject *self, connectionObject *conn, | ||||||
|               Oid oid, const char *smode, Oid new_oid, const char *new_file) |               Oid oid, const char *smode, Oid new_oid, const char *new_file) | ||||||
| { | { | ||||||
|  | @ -237,7 +237,7 @@ lobject_open(lobjectObject *self, connectionObject *conn, | ||||||
| 
 | 
 | ||||||
| /* lobject_close - close an existing lo */ | /* lobject_close - close an existing lo */ | ||||||
| 
 | 
 | ||||||
| static int | RAISES_NEG static int | ||||||
| lobject_close_locked(lobjectObject *self, char **error) | lobject_close_locked(lobjectObject *self, char **error) | ||||||
| { | { | ||||||
|     int retvalue; |     int retvalue; | ||||||
|  | @ -270,7 +270,7 @@ lobject_close_locked(lobjectObject *self, char **error) | ||||||
|     return retvalue; |     return retvalue; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int | RAISES_NEG int | ||||||
| lobject_close(lobjectObject *self) | lobject_close(lobjectObject *self) | ||||||
| { | { | ||||||
|     PGresult *pgres = NULL; |     PGresult *pgres = NULL; | ||||||
|  | @ -292,7 +292,7 @@ lobject_close(lobjectObject *self) | ||||||
| 
 | 
 | ||||||
| /* lobject_unlink - remove an lo from database */ | /* lobject_unlink - remove an lo from database */ | ||||||
| 
 | 
 | ||||||
| int | RAISES_NEG int | ||||||
| lobject_unlink(lobjectObject *self) | lobject_unlink(lobjectObject *self) | ||||||
| { | { | ||||||
|     PGresult *pgres = NULL; |     PGresult *pgres = NULL; | ||||||
|  | @ -326,7 +326,7 @@ lobject_unlink(lobjectObject *self) | ||||||
| 
 | 
 | ||||||
| /* lobject_write - write bytes to a lo */ | /* lobject_write - write bytes to a lo */ | ||||||
| 
 | 
 | ||||||
| Py_ssize_t | RAISES_NEG Py_ssize_t | ||||||
| lobject_write(lobjectObject *self, const char *buf, size_t len) | lobject_write(lobjectObject *self, const char *buf, size_t len) | ||||||
| { | { | ||||||
|     Py_ssize_t written; |     Py_ssize_t written; | ||||||
|  | @ -353,7 +353,7 @@ lobject_write(lobjectObject *self, const char *buf, size_t len) | ||||||
| 
 | 
 | ||||||
| /* lobject_read - read bytes from a lo */ | /* lobject_read - read bytes from a lo */ | ||||||
| 
 | 
 | ||||||
| Py_ssize_t | RAISES_NEG Py_ssize_t | ||||||
| lobject_read(lobjectObject *self, char *buf, size_t len) | lobject_read(lobjectObject *self, char *buf, size_t len) | ||||||
| { | { | ||||||
|     Py_ssize_t n_read; |     Py_ssize_t n_read; | ||||||
|  | @ -377,7 +377,7 @@ lobject_read(lobjectObject *self, char *buf, size_t len) | ||||||
| 
 | 
 | ||||||
| /* lobject_seek - move the current position in the lo */ | /* lobject_seek - move the current position in the lo */ | ||||||
| 
 | 
 | ||||||
| int | RAISES_NEG int | ||||||
| lobject_seek(lobjectObject *self, int pos, int whence) | lobject_seek(lobjectObject *self, int pos, int whence) | ||||||
| { | { | ||||||
|     PGresult *pgres = NULL; |     PGresult *pgres = NULL; | ||||||
|  | @ -405,7 +405,7 @@ lobject_seek(lobjectObject *self, int pos, int whence) | ||||||
| 
 | 
 | ||||||
| /* lobject_tell - tell the current position in the lo */ | /* lobject_tell - tell the current position in the lo */ | ||||||
| 
 | 
 | ||||||
| int | RAISES_NEG int | ||||||
| lobject_tell(lobjectObject *self) | lobject_tell(lobjectObject *self) | ||||||
| { | { | ||||||
|     PGresult *pgres = NULL; |     PGresult *pgres = NULL; | ||||||
|  | @ -432,7 +432,7 @@ lobject_tell(lobjectObject *self) | ||||||
| 
 | 
 | ||||||
| /* lobject_export - export to a local file */ | /* lobject_export - export to a local file */ | ||||||
| 
 | 
 | ||||||
| int | RAISES_NEG int | ||||||
| lobject_export(lobjectObject *self, const char *filename) | lobject_export(lobjectObject *self, const char *filename) | ||||||
| { | { | ||||||
|     PGresult *pgres = NULL; |     PGresult *pgres = NULL; | ||||||
|  | @ -461,7 +461,7 @@ lobject_export(lobjectObject *self, const char *filename) | ||||||
| 
 | 
 | ||||||
| #if PG_VERSION_HEX >= 0x080300 | #if PG_VERSION_HEX >= 0x080300 | ||||||
| 
 | 
 | ||||||
| int | RAISES_NEG int | ||||||
| lobject_truncate(lobjectObject *self, size_t len) | lobject_truncate(lobjectObject *self, size_t len) | ||||||
| { | { | ||||||
|     int retvalue; |     int retvalue; | ||||||
|  |  | ||||||
|  | @ -143,14 +143,6 @@ psyco_connect(PyObject *self, PyObject *args, PyObject *keywds) | ||||||
| "  * `name`: Name for the new type\n" \ | "  * `name`: Name for the new type\n" \ | ||||||
| "  * `baseobj`: Adapter to perform type conversion of a single array item." | "  * `baseobj`: Adapter to perform type conversion of a single array item." | ||||||
| 
 | 
 | ||||||
| static void |  | ||||||
| _psyco_register_type_set(PyObject **dict, PyObject *type) |  | ||||||
| { |  | ||||||
|     if (*dict == NULL) |  | ||||||
|         *dict = PyDict_New(); |  | ||||||
|     typecast_add(type, *dict, 0); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static PyObject * | static PyObject * | ||||||
| psyco_register_type(PyObject *self, PyObject *args) | psyco_register_type(PyObject *self, PyObject *args) | ||||||
| { | { | ||||||
|  | @ -162,10 +154,16 @@ psyco_register_type(PyObject *self, PyObject *args) | ||||||
| 
 | 
 | ||||||
|     if (obj != NULL && obj != Py_None) { |     if (obj != NULL && obj != Py_None) { | ||||||
|         if (PyObject_TypeCheck(obj, &cursorType)) { |         if (PyObject_TypeCheck(obj, &cursorType)) { | ||||||
|             _psyco_register_type_set(&(((cursorObject*)obj)->string_types), type); |             PyObject **dict = &(((cursorObject*)obj)->string_types); | ||||||
|  |             if (*dict == NULL) { | ||||||
|  |                 if (!(*dict = PyDict_New())) { return NULL; } | ||||||
|  |             } | ||||||
|  |             if (0 > typecast_add(type, *dict, 0)) { return NULL; } | ||||||
|         } |         } | ||||||
|         else if (PyObject_TypeCheck(obj, &connectionType)) { |         else if (PyObject_TypeCheck(obj, &connectionType)) { | ||||||
|             typecast_add(type, ((connectionObject*)obj)->string_types, 0); |             if (0 > typecast_add(type, ((connectionObject*)obj)->string_types, 0)) { | ||||||
|  |                 return NULL; | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         else { |         else { | ||||||
|             PyErr_SetString(PyExc_TypeError, |             PyErr_SetString(PyExc_TypeError, | ||||||
|  | @ -174,7 +172,7 @@ psyco_register_type(PyObject *self, PyObject *args) | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         typecast_add(type, NULL, 0); |         if (0 > typecast_add(type, NULL, 0)) { return NULL; } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Py_INCREF(Py_None); |     Py_INCREF(Py_None); | ||||||
|  | @ -1001,7 +999,7 @@ INIT_MODULE(_psycopg)(void) | ||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
|     /* initialize default set of typecasters */ |     /* initialize default set of typecasters */ | ||||||
|     typecast_init(dict); |     if (0 != typecast_init(dict)) { goto exit; } | ||||||
| 
 | 
 | ||||||
|     /* initialize microprotocols layer */ |     /* initialize microprotocols layer */ | ||||||
|     microprotocols_init(dict); |     microprotocols_init(dict); | ||||||
|  |  | ||||||
|  | @ -250,7 +250,7 @@ PyObject *psyco_default_binary_cast; | ||||||
| 
 | 
 | ||||||
| /* typecast_init - initialize the dictionary and create default types */ | /* typecast_init - initialize the dictionary and create default types */ | ||||||
| 
 | 
 | ||||||
| int | RAISES_NEG int | ||||||
| typecast_init(PyObject *dict) | typecast_init(PyObject *dict) | ||||||
| { | { | ||||||
|     int i; |     int i; | ||||||
|  | @ -316,7 +316,7 @@ typecast_init(PyObject *dict) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* typecast_add - add a type object to the dictionary */ | /* typecast_add - add a type object to the dictionary */ | ||||||
| int | RAISES_NEG int | ||||||
| typecast_add(PyObject *obj, PyObject *dict, int binary) | typecast_add(PyObject *obj, PyObject *dict, int binary) | ||||||
| { | { | ||||||
|     PyObject *val; |     PyObject *val; | ||||||
|  |  | ||||||
|  | @ -71,8 +71,8 @@ extern HIDDEN PyObject *psyco_default_binary_cast; | ||||||
| /** exported functions **/ | /** exported functions **/ | ||||||
| 
 | 
 | ||||||
| /* used by module.c to init the type system and register types */ | /* used by module.c to init the type system and register types */ | ||||||
| HIDDEN int typecast_init(PyObject *dict); | RAISES_NEG HIDDEN int typecast_init(PyObject *dict); | ||||||
| HIDDEN int typecast_add(PyObject *obj, PyObject *dict, int binary); | RAISES_NEG HIDDEN int typecast_add(PyObject *obj, PyObject *dict, int binary); | ||||||
| 
 | 
 | ||||||
| /* the C callable typecastObject creator function */ | /* the C callable typecastObject creator function */ | ||||||
| HIDDEN PyObject *typecast_from_c(typecastObject_initlist *type, PyObject *d); | HIDDEN PyObject *typecast_from_c(typecastObject_initlist *type, PyObject *d); | ||||||
|  |  | ||||||
|  | @ -166,7 +166,7 @@ typecast_array_tokenize(const char *str, Py_ssize_t strlength, | ||||||
|     return res; |     return res; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int | RAISES_NEG static int | ||||||
| typecast_array_scan(const char *str, Py_ssize_t strlength, | typecast_array_scan(const char *str, Py_ssize_t strlength, | ||||||
|                     PyObject *curs, PyObject *base, PyObject *array) |                     PyObject *curs, PyObject *base, PyObject *array) | ||||||
| { | { | ||||||
|  | @ -199,7 +199,7 @@ typecast_array_scan(const char *str, Py_ssize_t strlength, | ||||||
| 
 | 
 | ||||||
|             /* before anything else we free the memory */ |             /* before anything else we free the memory */ | ||||||
|             if (state == ASCAN_QUOTED) PyMem_Free(token); |             if (state == ASCAN_QUOTED) PyMem_Free(token); | ||||||
|             if (obj == NULL) return 0; |             if (obj == NULL) return -1; | ||||||
| 
 | 
 | ||||||
|             PyList_Append(array, obj); |             PyList_Append(array, obj); | ||||||
|             Py_DECREF(obj); |             Py_DECREF(obj); | ||||||
|  | @ -207,25 +207,25 @@ typecast_array_scan(const char *str, Py_ssize_t strlength, | ||||||
| 
 | 
 | ||||||
|         else if (state == ASCAN_BEGIN) { |         else if (state == ASCAN_BEGIN) { | ||||||
|             PyObject *sub = PyList_New(0); |             PyObject *sub = PyList_New(0); | ||||||
|             if (sub == NULL) return 0; |             if (sub == NULL) return -1; | ||||||
| 
 | 
 | ||||||
|             PyList_Append(array, sub); |             PyList_Append(array, sub); | ||||||
|             Py_DECREF(sub); |             Py_DECREF(sub); | ||||||
| 
 | 
 | ||||||
|             if (stack_index == MAX_DIMENSIONS) |             if (stack_index == MAX_DIMENSIONS) | ||||||
|                 return 0; |                 return -1; | ||||||
| 
 | 
 | ||||||
|             stack[stack_index++] = array; |             stack[stack_index++] = array; | ||||||
|             array = sub; |             array = sub; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         else if (state == ASCAN_ERROR) { |         else if (state == ASCAN_ERROR) { | ||||||
|             return 0; |             return -1; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         else if (state == ASCAN_END) { |         else if (state == ASCAN_END) { | ||||||
|             if (--stack_index < 0) |             if (--stack_index < 0) | ||||||
|                 return 0; |                 return -1; | ||||||
|             array = stack[stack_index]; |             array = stack[stack_index]; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -233,7 +233,7 @@ typecast_array_scan(const char *str, Py_ssize_t strlength, | ||||||
|             break; |             break; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return 1; |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -263,9 +263,8 @@ typecast_GENERIC_ARRAY_cast(const char *str, Py_ssize_t len, PyObject *curs) | ||||||
|     obj = PyList_New(0); |     obj = PyList_New(0); | ||||||
| 
 | 
 | ||||||
|     /* scan the array skipping the first level of {} */ |     /* scan the array skipping the first level of {} */ | ||||||
|     if (typecast_array_scan(&str[1], len-2, curs, base, obj) == 0) { |     if (typecast_array_scan(&str[1], len-2, curs, base, obj) < 0) { | ||||||
|         Py_DECREF(obj); |         Py_CLEAR(obj); | ||||||
|         obj = NULL; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return obj; |     return obj; | ||||||
|  |  | ||||||
|  | @ -26,7 +26,7 @@ | ||||||
| #include <math.h> | #include <math.h> | ||||||
| #include "datetime.h" | #include "datetime.h" | ||||||
| 
 | 
 | ||||||
| static int | RAISES_NEG static int | ||||||
| psyco_typecast_datetime_init(void) | psyco_typecast_datetime_init(void) | ||||||
| { | { | ||||||
|     Dprintf("psyco_typecast_datetime_init: datetime init"); |     Dprintf("psyco_typecast_datetime_init: datetime init"); | ||||||
|  |  | ||||||
|  | @ -486,7 +486,7 @@ exit: | ||||||
|  * |  * | ||||||
|  * Return a borrowed reference. */ |  * Return a borrowed reference. */ | ||||||
| 
 | 
 | ||||||
| static PyObject * | BORROWED static PyObject * | ||||||
| _xid_get_parse_regex(void) { | _xid_get_parse_regex(void) { | ||||||
|     static PyObject *rv; |     static PyObject *rv; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user