summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy
diff options
context:
space:
mode:
authormike bayer <mike_mp@zzzcomputing.com>2022-12-27 20:53:08 +0000
committerGerrit Code Review <gerrit@ci3.zzzcomputing.com>2022-12-27 20:53:08 +0000
commit6eceb939744e000e627edeabe2da4694fa193eff (patch)
tree8b518b0395479681ca6ac5ff9c310886e11b91ae /lib/sqlalchemy
parente0ea78bd079c1545ced7c9233f949fabe296cd07 (diff)
parent502df8a4730abf999546e1910270004c194b0c08 (diff)
downloadsqlalchemy-6eceb939744e000e627edeabe2da4694fa193eff.tar.gz
Merge "pass more contextual information to PyWrapper param create" into main
Diffstat (limited to 'lib/sqlalchemy')
-rw-r--r--lib/sqlalchemy/sql/coercions.py9
-rw-r--r--lib/sqlalchemy/sql/lambdas.py15
2 files changed, 17 insertions, 7 deletions
diff --git a/lib/sqlalchemy/sql/coercions.py b/lib/sqlalchemy/sql/coercions.py
index 9c3e7480a..7a4e68773 100644
--- a/lib/sqlalchemy/sql/coercions.py
+++ b/lib/sqlalchemy/sql/coercions.py
@@ -355,7 +355,12 @@ def expect(
if not isinstance(
element,
- (elements.CompilerElement, schema.SchemaItem, schema.FetchedValue),
+ (
+ elements.CompilerElement,
+ schema.SchemaItem,
+ schema.FetchedValue,
+ lambdas.PyWrapper,
+ ),
):
resolved = None
@@ -404,6 +409,8 @@ def expect(
)
else:
resolved = element
+ elif isinstance(element, lambdas.PyWrapper):
+ resolved = element._sa__py_wrapper_literal(**kw)
else:
resolved = element
diff --git a/lib/sqlalchemy/sql/lambdas.py b/lib/sqlalchemy/sql/lambdas.py
index 26e3a21bb..d9b4988a6 100644
--- a/lib/sqlalchemy/sql/lambdas.py
+++ b/lib/sqlalchemy/sql/lambdas.py
@@ -33,7 +33,6 @@ from . import coercions
from . import elements
from . import roles
from . import schema
-from . import type_api
from . import visitors
from .base import _clone
from .base import Executable
@@ -1308,11 +1307,11 @@ class PyWrapper(ColumnOperators):
return value
def operate(self, op, *other, **kwargs):
- elem = object.__getattribute__(self, "__clause_element__")()
+ elem = object.__getattribute__(self, "_py_wrapper_literal")()
return op(elem, *other, **kwargs)
def reverse_operate(self, op, other, **kwargs):
- elem = object.__getattribute__(self, "__clause_element__")()
+ elem = object.__getattribute__(self, "_py_wrapper_literal")()
return op(other, elem, **kwargs)
def _extract_bound_parameters(self, starting_point, result_list):
@@ -1325,16 +1324,19 @@ class PyWrapper(ColumnOperators):
element = getter(starting_point)
pywrapper._sa__extract_bound_parameters(element, result_list)
- def __clause_element__(self):
+ def _py_wrapper_literal(self, expr=None, operator=None, **kw):
param = object.__getattribute__(self, "_param")
to_evaluate = object.__getattribute__(self, "_to_evaluate")
if param is None:
name = object.__getattribute__(self, "_name")
self._param = param = elements.BindParameter(
- name, required=False, unique=True
+ name,
+ required=False,
+ unique=True,
+ _compared_to_operator=operator,
+ _compared_to_type=expr.type if expr is not None else None,
)
self._has_param = True
- param.type = type_api._resolve_value_to_type(to_evaluate)
return param._with_value(to_evaluate, maintain_key=True)
def __bool__(self):
@@ -1348,6 +1350,7 @@ class PyWrapper(ColumnOperators):
"__clause_element__",
"operate",
"reverse_operate",
+ "_py_wrapper_literal",
"__class__",
"__dict__",
):