elif self.engine.paramstyle=='format':
self.strings[self.statement] = re.sub(match, '%s', self.strings[self.statement])
elif self.engine.paramstyle=='numeric':
- i = 0
+ i = [0]
def getnum(x):
- i += 1
- return i
- self.strings[self.statement] = re.sub(match, getnum(s), self.strings[self.statement])
+ i[0] += 1
+ return str(i[0])
+ self.strings[self.statement] = re.sub(match, getnum, self.strings[self.statement])
def get_from_text(self, obj):
return self.froms[obj]
if self.parameters is not None:
revisit = False
for c in inner_columns.values():
- if self.parameters.has_key(c.key) and not self.binds.has_key(c.key):
+ if sql.is_column(c) and self.parameters.has_key(c.key) and not self.binds.has_key(c.key):
value = self.parameters[c.key]
else:
continue
else:
self.logger = logger
- def _figure_paramstyle(self):
+ def _set_paramstyle(self, style):
+ self._paramstyle = style
+ self._figure_paramstyle(style)
+ paramstyle = property(lambda s:s._paramstyle, _set_paramstyle)
+
+ def _figure_paramstyle(self, paramstyle=None):
db = self.dbapi()
- if db is not None:
- self.paramstyle = db.paramstyle
+ if paramstyle is not None:
+ self._paramstyle = paramstyle
+ elif db is not None:
+ self._paramstyle = db.paramstyle
else:
- self.paramstyle = 'named'
+ self._paramstyle = 'named'
- if self.paramstyle == 'named':
+ if self._paramstyle == 'named':
self.bindtemplate = ':%s'
self.positional=False
- elif self.paramstyle =='pyformat':
+ elif self._paramstyle == 'pyformat':
self.bindtemplate = "%%(%s)s"
self.positional=False
- else:
- # for positional, use pyformat until the end
+ elif self._paramstyle == 'qmark' or self._paramstyle == 'format' or self._paramstyle == 'numeric':
+ # for positional, use pyformat internally, ANSICompiler will convert
+ # to appropriate character upon compilation
self.bindtemplate = "%%(%s)s"
- self.positional=True
+ self.positional = True
+ else:
+ raise "Unsupported paramstyle '%s'" % self._paramstyle
def type_descriptor(self, typeobj):
"""provides a database-specific TypeEngine object, given the generic object
# load custom properties
if properties is not None:
for key, prop in properties.iteritems():
- if is_column(prop):
+ if sql.is_column(prop):
self.columns[key] = prop
prop = ColumnProperty(prop)
- elif isinstance(prop, list) and is_column(prop[0]):
+ elif isinstance(prop, list) and sql.is_column(prop[0]):
self.columns[key] = prop[0]
prop = ColumnProperty(*prop)
self.props[key] = prop
def add_property(self, key, prop):
self.copyargs['properties'][key] = prop
- if is_column(prop):
+ if sql.is_column(prop):
self.columns[key] = prop
prop = ColumnProperty(prop)
self.props[key] = prop
return obj.hash_key()
else:
return repr(obj)
-
-def is_column(col):
- return isinstance(col, schema.Column) or isinstance(col, sql.ColumnElement)
def mapper_hash_key(class_, table, primarytable = None, properties = None, **kwargs):
if properties is None:
def _is_literal(element):
return not isinstance(element, ClauseElement) and not isinstance(element, schema.SchemaItem)
+def is_column(col):
+ return isinstance(col, schema.Column) or isinstance(col, ColumnElement)
+
class ClauseVisitor(schema.SchemaVisitor):
"""builds upon SchemaVisitor to define the visiting of SQL statement elements in
addition to Schema elements."""