summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2007-07-20 18:35:51 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2007-07-20 18:35:51 +0000
commit794c43c5aea11228edbb645e62b54377b9937948 (patch)
tree5af5a1be7218bddfe7051153c97cc26f7acf3854 /lib
parentc1bf74462f7f2c86cabe725be68ff540b2a47bdb (diff)
downloadsqlalchemy-794c43c5aea11228edbb645e62b54377b9937948.tar.gz
further adjustment to pool.get
Diffstat (limited to 'lib')
-rw-r--r--lib/sqlalchemy/pool.py8
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/sqlalchemy/pool.py b/lib/sqlalchemy/pool.py
index cf442c928..8670464a0 100644
--- a/lib/sqlalchemy/pool.py
+++ b/lib/sqlalchemy/pool.py
@@ -491,10 +491,14 @@ class QueuePool(Pool):
def do_get(self):
try:
- return self._pool.get(self._max_overflow > -1 and self._overflow >= self._max_overflow, self._timeout)
+ wait = self._max_overflow > -1 and self._overflow >= self._max_overflow
+ return self._pool.get(wait, self._timeout)
except Queue.Empty:
if self._max_overflow > -1 and self._overflow >= self._max_overflow:
- raise exceptions.TimeoutError("QueuePool limit of size %d overflow %d reached, connection timed out, timeout %d" % (self.size(), self.overflow(), self._timeout))
+ if not wait:
+ return self.do_get()
+ else:
+ raise exceptions.TimeoutError("QueuePool limit of size %d overflow %d reached, connection timed out, timeout %d" % (self.size(), self.overflow(), self._timeout))
if self._overflow_lock is not None:
self._overflow_lock.acquire()