mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Made Extracts aware of full lookup path
This commit is contained in:
		| @@ -6,8 +6,9 @@ from django.utils.functional import cached_property | |||||||
|  |  | ||||||
|  |  | ||||||
| class Extract(object): | class Extract(object): | ||||||
|     def __init__(self, lhs): |     def __init__(self, lhs, lookups): | ||||||
|         self.lhs = lhs |         self.lhs = lhs | ||||||
|  |         self.init_lookups = lookups[:] | ||||||
|  |  | ||||||
|     def get_lookup(self, lookup): |     def get_lookup(self, lookup): | ||||||
|         return self.output_type.get_lookup(lookup) |         return self.output_type.get_lookup(lookup) | ||||||
|   | |||||||
| @@ -1082,26 +1082,27 @@ class Query(object): | |||||||
|  |  | ||||||
|     def build_lookup(self, lookups, lhs, rhs): |     def build_lookup(self, lookups, lhs, rhs): | ||||||
|         lookups = lookups[:] |         lookups = lookups[:] | ||||||
|         lookups.reverse() |  | ||||||
|         while lookups: |         while lookups: | ||||||
|             lookup = lookups.pop() |             lookup = lookups[0] | ||||||
|             next = lhs.get_lookup(lookup) |             next = lhs.get_lookup(lookup) | ||||||
|             if next: |             if next: | ||||||
|                 if not lookups: |                 if len(lookups) == 1: | ||||||
|                     # This was the last lookup, so return value lookup. |                     # This was the last lookup, so return value lookup. | ||||||
|                     if issubclass(next, Extract): |                     if issubclass(next, Extract): | ||||||
|                         lhs = next(lhs) |                         lookups.append('exact') | ||||||
|                         next = lhs.get_lookup('exact') |                         lhs = next(lhs, lookups) | ||||||
|                     return next(lhs, rhs) |                     else: | ||||||
|  |                         return next(lhs, rhs) | ||||||
|                 else: |                 else: | ||||||
|                     lhs = next(lhs) |                     lhs = next(lhs, lookups) | ||||||
|             # A field's get_lookup() can return None to opt for backwards |             # A field's get_lookup() can return None to opt for backwards | ||||||
|             # compatibility path. |             # compatibility path. | ||||||
|             elif len(lookups) > 1: |             elif len(lookups) > 2: | ||||||
|                 raise FieldError( |                 raise FieldError( | ||||||
|                     "Unsupported lookup for field '%s'" % lhs.output_type.name) |                     "Unsupported lookup for field '%s'" % lhs.output_type.name) | ||||||
|             else: |             else: | ||||||
|                 return None |                 return None | ||||||
|  |             lookups = lookups[1:] | ||||||
|  |  | ||||||
|     def build_filter(self, filter_expr, branch_negated=False, current_negated=False, |     def build_filter(self, filter_expr, branch_negated=False, current_negated=False, | ||||||
|                      can_reuse=None, connector=AND): |                      can_reuse=None, connector=AND): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user