mirror of
https://github.com/psycopg/psycopg2.git
synced 2025-02-07 21:00:33 +03:00
Fixed cursor() arguments propagation to other connection classes
This commit is contained in:
parent
095cce5605
commit
c86ca7687f
|
@ -104,8 +104,7 @@ class DictCursorBase(_cursor):
|
|||
class DictConnection(_connection):
|
||||
"""A connection that uses `DictCursor` automatically."""
|
||||
def cursor(self, *args, **kwargs):
|
||||
if 'cursor_factory' not in kwargs:
|
||||
kwargs['cursor_factory'] = DictCursor
|
||||
kwargs.setdefault('cursor_factory', DictCursor)
|
||||
return _connection.cursor(self, *args, **kwargs)
|
||||
|
||||
class DictCursor(DictCursorBase):
|
||||
|
@ -196,8 +195,7 @@ class DictRow(list):
|
|||
class RealDictConnection(_connection):
|
||||
"""A connection that uses `RealDictCursor` automatically."""
|
||||
def cursor(self, *args, **kwargs):
|
||||
if 'cursor_factory' not in kwargs:
|
||||
kwargs['cursor_factory'] = RealDictCursor
|
||||
kwargs.setdefault('cursor_factory', RealDictCursor)
|
||||
return _connection.cursor(self, *args, **kwargs)
|
||||
|
||||
class RealDictCursor(DictCursorBase):
|
||||
|
@ -252,8 +250,7 @@ class RealDictRow(dict):
|
|||
class NamedTupleConnection(_connection):
|
||||
"""A connection that uses `NamedTupleCursor` automatically."""
|
||||
def cursor(self, *args, **kwargs):
|
||||
if 'cursor_factory' not in kwargs:
|
||||
kwargs['cursor_factory'] = NamedTupleCursor
|
||||
kwargs.setdefault('cursor_factory', NamedTupleCursor)
|
||||
return _connection.cursor(self, *args, **kwargs)
|
||||
|
||||
class NamedTupleCursor(_cursor):
|
||||
|
@ -371,12 +368,10 @@ class LoggingConnection(_connection):
|
|||
raise self.ProgrammingError(
|
||||
"LoggingConnection object has not been initialize()d")
|
||||
|
||||
def cursor(self, name=None):
|
||||
def cursor(self, *args, **kwargs):
|
||||
self._check()
|
||||
if name is None:
|
||||
return _connection.cursor(self, cursor_factory=LoggingCursor)
|
||||
else:
|
||||
return _connection.cursor(self, name, cursor_factory=LoggingCursor)
|
||||
kwargs.setdefault('cursor_factory', LoggingCursor)
|
||||
return _connection.cursor(self, *args, **kwargs)
|
||||
|
||||
class LoggingCursor(_cursor):
|
||||
"""A cursor that logs queries using its connection logging facilities."""
|
||||
|
@ -414,12 +409,9 @@ class MinTimeLoggingConnection(LoggingConnection):
|
|||
if t > self._mintime:
|
||||
return msg + os.linesep + " (execution time: %d ms)" % t
|
||||
|
||||
def cursor(self, name=None):
|
||||
self._check()
|
||||
if name is None:
|
||||
return _connection.cursor(self, cursor_factory=MinTimeLoggingCursor)
|
||||
else:
|
||||
return _connection.cursor(self, name, cursor_factory=MinTimeLoggingCursor)
|
||||
def cursor(self, *args, **kwargs):
|
||||
kwargs.setdefault('cursor_factory', MinTimeLoggingCursor)
|
||||
return LoggingConnection.cursor(self, *args, **kwargs)
|
||||
|
||||
class MinTimeLoggingCursor(LoggingCursor):
|
||||
"""The cursor sub-class companion to `MinTimeLoggingConnection`."""
|
||||
|
|
Loading…
Reference in New Issue
Block a user