]> git.ipfire.org Git - thirdparty/sqlalchemy/sqlalchemy.git/commitdiff
fix to typing in clause construction which specifically helps
authorMike Bayer <mike_mp@zzzcomputing.com>
Wed, 19 Jul 2006 16:10:15 +0000 (16:10 +0000)
committerMike Bayer <mike_mp@zzzcomputing.com>
Wed, 19 Jul 2006 16:10:15 +0000 (16:10 +0000)
type issues with polymorphic_union (CAST/ColumnClause propigates
its type to proxy columns)

CHANGES
lib/sqlalchemy/sql.py

diff --git a/CHANGES b/CHANGES
index 9f3250224b627d49000b6acec1e623cb3d481753..8875727c2949d1f96e226145d8c27ccd2cda0415 100644 (file)
--- a/CHANGES
+++ b/CHANGES
@@ -32,6 +32,9 @@ a flush() under some circumstances, this was fixed
 - added "synonym()" function, applied to properties to have a 
 propname the same as another, for the purposes of overriding props
 and allowing the original propname to be accessible in select_by().
+- fix to typing in clause construction which specifically helps
+type issues with polymorphic_union (CAST/ColumnClause propigates
+its type to proxy columns)
 
 0.2.5
 - fixed endless loop bug in select_by(), if the traversal hit
index 8109d8cd52bbc60ca433db9ced8be4528f6867a4..e0b8866f62a0c2a95bfca2271ea4896ed035896a 100644 (file)
@@ -985,7 +985,15 @@ class Cast(ColumnElement):
         visitor.visit_cast(self)
     def _get_from_objects(self):
         return self.clause._get_from_objects()
-        
+    def _make_proxy(self, selectable, name=None):
+        if name is not None:
+            co = ColumnClause(name, selectable, type=self.type)
+            co.orig_set = self.orig_set
+            selectable.columns[name]= co
+            return co
+        else:
+            return self
+            
 class FunctionGenerator(object):
     """generates Function objects based on getattr calls"""
     def __init__(self, engine=None):
@@ -1210,7 +1218,7 @@ class ColumnClause(ColumnElement):
     def _bind_param(self, obj):
         return BindParamClause(self._label, obj, shortname = self.name, type=self.type)
     def _make_proxy(self, selectable, name = None):
-        c = ColumnClause(name or self.name, selectable, hidden=self.hidden)
+        c = ColumnClause(name or self.name, selectable, hidden=self.hidden, type=self.type)
         c.orig_set = self.orig_set
         if not self.hidden:
             selectable.columns[c.name] = c
@@ -1349,7 +1357,6 @@ class CompoundSelect(SelectBaseMixin, FromClause):
             col = column._make_proxy(self, name=column._label)
         else:
             col = column._make_proxy(self, name=column.name)
-        
         try:
             colset = self._col_map[col.name]
         except KeyError: