diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-07-20 18:35:51 +0000 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-07-20 18:35:51 +0000 |
| commit | 794c43c5aea11228edbb645e62b54377b9937948 (patch) | |
| tree | 5af5a1be7218bddfe7051153c97cc26f7acf3854 /lib | |
| parent | c1bf74462f7f2c86cabe725be68ff540b2a47bdb (diff) | |
| download | sqlalchemy-794c43c5aea11228edbb645e62b54377b9937948.tar.gz | |
further adjustment to pool.get
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/sqlalchemy/pool.py | 8 |
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() |
