diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2011-06-08 17:37:42 -0400 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2011-06-08 17:37:42 -0400 |
commit | ac9a007c507dbf31a55f1f8beb6da54a7aadedc5 (patch) | |
tree | ff6e983e16007ae50927538438defc189d4a3ce3 /lib/sqlalchemy/sql/expression.py | |
parent | 2f88fd7c6f0250a914675b2fe609be9ed1f72cee (diff) | |
download | sqlalchemy-ac9a007c507dbf31a55f1f8beb6da54a7aadedc5.tar.gz |
- Added the same "columns-only" check to
mapper.polymorphic_on as used in
relationship.order_by, foreign_keys,
remote_side, etc.
Diffstat (limited to 'lib/sqlalchemy/sql/expression.py')
-rw-r--r-- | lib/sqlalchemy/sql/expression.py | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/lib/sqlalchemy/sql/expression.py b/lib/sqlalchemy/sql/expression.py index ec0801405..8eb552de9 100644 --- a/lib/sqlalchemy/sql/expression.py +++ b/lib/sqlalchemy/sql/expression.py @@ -1334,12 +1334,19 @@ def _no_literals(element): else: return element +def _only_column_elements_or_none(element, name): + if element is None: + return None + else: + return _only_column_elements(element, name) + def _only_column_elements(element, name): if hasattr(element, '__clause_element__'): element = element.__clause_element__() if not isinstance(element, ColumnElement): - raise exc.ArgumentError("Column-based expression object expected for argument '%s'; " - "got: '%s', type %s" % (name, element, type(element))) + raise exc.ArgumentError( + "Column-based expression object expected for argument " + "'%s'; got: '%s', type %s" % (name, element, type(element))) return element def _corresponding_column_or_error(fromclause, column, |