Use conditional function definition
parent
45215ff6c3
commit
fa6808e9b3
|
|
@ -158,18 +158,34 @@ class PolymorphicQuerySet(QuerySet):
|
|||
# Implementation in _translate_polymorphic_filter_defnition."""
|
||||
return self.filter(not_instance_of=args)
|
||||
|
||||
def _filter_or_exclude(self, negate, *args, **kwargs):
|
||||
# We override this internal Django function as it is used for all filter member functions.
|
||||
q_objects = translate_polymorphic_filter_definitions_in_args(
|
||||
self.model, args, using=self.db
|
||||
)
|
||||
# filter_field='data'
|
||||
additional_args = translate_polymorphic_filter_definitions_in_kwargs(
|
||||
self.model, kwargs, using=self.db
|
||||
)
|
||||
return super(PolymorphicQuerySet, self)._filter_or_exclude(
|
||||
negate, *(list(q_objects) + additional_args), **kwargs
|
||||
)
|
||||
# Makes _filter_or_exclude compatible with the change in signature introduced in django at 9c9a3fe
|
||||
if get_django_version() >= "3.2":
|
||||
def _filter_or_exclude(self, negate, args, kwargs):
|
||||
# We override this internal Django function as it is used for all filter member functions.
|
||||
q_objects = translate_polymorphic_filter_definitions_in_args(
|
||||
queryset_model=self.model, args=args, using=self.db
|
||||
)
|
||||
# filter_field='data'
|
||||
additional_args = translate_polymorphic_filter_definitions_in_kwargs(
|
||||
queryset_model=self.model, kwargs=kwargs, using=self.db
|
||||
)
|
||||
args = list(q_objects) + additional_args
|
||||
return super(PolymorphicQuerySet, self)._filter_or_exclude(
|
||||
negate=negate, args=args, kwargs=kwargs
|
||||
)
|
||||
else:
|
||||
def _filter_or_exclude(self, negate, *args, **kwargs):
|
||||
# We override this internal Django function as it is used for all filter member functions.
|
||||
q_objects = translate_polymorphic_filter_definitions_in_args(
|
||||
self.model, args, using=self.db
|
||||
)
|
||||
# filter_field='data'
|
||||
additional_args = translate_polymorphic_filter_definitions_in_kwargs(
|
||||
self.model, kwargs, using=self.db
|
||||
)
|
||||
return super(PolymorphicQuerySet, self)._filter_or_exclude(
|
||||
negate, *(list(q_objects) + additional_args), **kwargs
|
||||
)
|
||||
|
||||
def order_by(self, *field_names):
|
||||
"""translate the field paths in the args, then call vanilla order_by."""
|
||||
|
|
@ -522,22 +538,4 @@ class PolymorphicQuerySet(QuerySet):
|
|||
if not self.model.polymorphic_query_multiline_output:
|
||||
return olist
|
||||
clist = PolymorphicQuerySet._p_list_class(olist)
|
||||
return clist
|
||||
|
||||
|
||||
# Makes _filter_or_exclude compatible with the change in signature introduced in django at 9c9a3fe
|
||||
if get_django_version() >= "3.2":
|
||||
def _filter_or_exclude(self, negate, args, kwargs):
|
||||
# We override this internal Django function as it is used for all filter member functions.
|
||||
q_objects = translate_polymorphic_filter_definitions_in_args(
|
||||
queryset_model=self.model, args=args, using=self.db
|
||||
)
|
||||
# filter_field='data'
|
||||
additional_args = translate_polymorphic_filter_definitions_in_kwargs(
|
||||
queryset_model=self.model, kwargs=kwargs, using=self.db
|
||||
)
|
||||
args = list(q_objects) + additional_args
|
||||
return super(PolymorphicQuerySet, self)._filter_or_exclude(
|
||||
negate=negate, args=args, kwargs=kwargs
|
||||
)
|
||||
PolymorphicQuerySet._filter_or_exclude = _filter_or_exclude
|
||||
return clist
|
||||
Loading…
Reference in New Issue