mirror of
				https://github.com/psycopg/psycopg2.git
				synced 2025-10-26 05:21:03 +03:00 
			
		
		
		
	First fixed to the async core.
This commit is contained in:
		
							parent
							
								
									b19922ebf3
								
							
						
					
					
						commit
						61b4ff6e6f
					
				
							
								
								
									
										10
									
								
								ChangeLog
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								ChangeLog
									
									
									
									
									
								
							|  | @ -1,3 +1,13 @@ | |||
| 2004-11-20  Federico Di Gregorio  <fog@initd.org> | ||||
| 
 | ||||
| 	* psycopg/cursor_type.c (_mogrify): ported %% fix from 1.1.15.  | ||||
| 
 | ||||
| 2004-11-20  Federico Di Gregorio  <fog@initd.org> | ||||
| 
 | ||||
| 	* psycopg/cursor_type.c (psyco_curs_execute): added check to raise an | ||||
| 	exception if a cursor tries to .execute() while an async query is | ||||
| 	already in execution froma  different cursor.  | ||||
| 
 | ||||
| 2004-11-20  Federico Di Gregorio  <fog@debian.org> | ||||
| 
 | ||||
| 	* psycopg/connection_type.c (psyco_conn_cursor): renamed 'cursor' | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| /* cursor_type.c - python interface to cursor objects
 | ||||
|  * | ||||
|  * Copyright (C) 2003 Federico Di Gregorio <fog@debian.org> | ||||
|  * Copyright (C) 2003-2004 Federico Di Gregorio <fog@debian.org> | ||||
|  * | ||||
|  * This file is part of psycopg. | ||||
|  * | ||||
|  | @ -66,7 +66,7 @@ _mogrify(PyObject *var, PyObject *fmt, connectionObject *conn, PyObject **new) | |||
| { | ||||
|     PyObject *key, *value, *n, *item; | ||||
|     char *d, *c; | ||||
|     int index = 0; | ||||
|     int index = 0, force = 0; | ||||
| 
 | ||||
|     /* from now on we'll use n and replace its value in *new only at the end,
 | ||||
|        just before returning. we also init *new to NULL to exit with an error | ||||
|  | @ -77,7 +77,7 @@ _mogrify(PyObject *var, PyObject *fmt, connectionObject *conn, PyObject **new) | |||
|     while(*c) { | ||||
|         /* handle plain percent symbol in format string */ | ||||
|         if (c[0] == '%' && c[1] == '%') { | ||||
|             c+=2; | ||||
|             c+=2; force = 1; | ||||
|         } | ||||
|          | ||||
|         /* if we find '%(' then this is a dictionary, we:
 | ||||
|  | @ -224,8 +224,11 @@ _mogrify(PyObject *var, PyObject *fmt, connectionObject *conn, PyObject **new) | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     if (force && n == NULL) | ||||
|         n = PyTuple_New(0); | ||||
|     *new = n; | ||||
|     return 0; | ||||
|      | ||||
|     return 0;; | ||||
| } | ||||
|      | ||||
| #define psyco_curs_execute_doc \ | ||||
|  | @ -246,6 +249,13 @@ psyco_curs_execute(cursorObject *self, PyObject *args, PyObject *kwargs) | |||
|         return NULL; | ||||
|     } | ||||
| 
 | ||||
|     if (self->conn->async_cursor != NULL | ||||
|         && self->conn->async_cursor != (PyObject*)self) { | ||||
|         PyErr_SetString(ProgrammingError, | ||||
|                         "asynchronous query already in execution"); | ||||
|         return NULL; | ||||
|     } | ||||
|      | ||||
|     if (PyUnicode_Check(operation)) { | ||||
|         PyObject *enc = PyDict_GetItemString(psycoEncodings, | ||||
|                                              self->conn->encoding); | ||||
|  | @ -970,7 +980,7 @@ cursor_next(PyObject *self) | |||
| { | ||||
|     PyObject *res; | ||||
| 
 | ||||
|     /* we don't parse argumente: psyco_curs_fetchone will do that for us */ | ||||
|     /* we don't parse arguments: psyco_curs_fetchone will do that for us */ | ||||
|     res = psyco_curs_fetchone((cursorObject*)self, NULL); | ||||
| 
 | ||||
|     /* convert a None to NULL to signal the end of iteration */ | ||||
|  |  | |||
|  | @ -1,12 +1,30 @@ | |||
| import datetime | ||||
| import time | ||||
| import psycopg | ||||
| 
 | ||||
| #d = datetime.timedelta(12, 100, 9876) | ||||
| #print d.days, d.seconds, d.microseconds | ||||
| #print psycopg.adapt(d).getquoted() | ||||
| 
 | ||||
| o = psycopg.connect("dbname=test") | ||||
| c = o.cursor() | ||||
| c.execute("SELECT 1.0 AS foo") | ||||
| print c.fetchmany(2) | ||||
| print c.fetchall() | ||||
| conn = psycopg.connect("dbname=test") | ||||
| curs = conn.cursor() | ||||
| #curs.execute("SELECT 1.0 AS foo") | ||||
| #print curs.fetchmany(2) | ||||
| #print curs.fetchall() | ||||
| 
 | ||||
| def sleep(curs): | ||||
|     while not curs.isready(): | ||||
|         print "." | ||||
|         time.sleep(.1) | ||||
|          | ||||
| #curs.execute(""" | ||||
| #    DECLARE zz INSENSITIVE SCROLL CURSOR WITH HOLD FOR | ||||
| #    SELECT now(); | ||||
| #    FOR READ ONLY;""", async = 1) | ||||
| curs.execute("SELECT now() AS foo", async=1); | ||||
| sleep(curs) | ||||
| 
 | ||||
| #curs.execute(""" | ||||
| #    FETCH FORWARD 1 FROM zz;""", async = 1) | ||||
| curs.execute("SELECT now() AS bar", async=1); | ||||
| sleep(curs) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user