Fixed review notes by Loic

This commit is contained in:
Anssi Kääriäinen 2013-12-21 23:06:29 +02:00
parent 049eebc070
commit b99c8d83c9
3 changed files with 26 additions and 24 deletions

View File

@ -1,5 +1,6 @@
from __future__ import unicode_literals from __future__ import unicode_literals
from collections import defaultdict
import datetime import datetime
import decimal import decimal
import hashlib import hashlib
@ -196,7 +197,7 @@ def format_number(value, max_digits, decimal_places):
return "%.*f" % (decimal_places, value) return "%.*f" % (decimal_places, value)
# Map of vendor name -> map of query element class -> implementation function # Map of vendor name -> map of query element class -> implementation function
compile_implementations = {} compile_implementations = defaultdict(dict)
def get_implementations(vendor): def get_implementations(vendor):

View File

@ -15,9 +15,10 @@ def refs_aggregate(lookup_parts, aggregates):
default annotation names we must check each prefix of the lookup_parts default annotation names we must check each prefix of the lookup_parts
for match. for match.
""" """
for i in range(len(lookup_parts) + 1): for n in range(len(lookup_parts) + 1):
if LOOKUP_SEP.join(lookup_parts[0:i]) in aggregates: level_n_lookup = LOOKUP_SEP.join(lookup_parts[0:n])
return aggregates[LOOKUP_SEP.join(lookup_parts[0:i])], lookup_parts[i:] if level_n_lookup in aggregates:
return aggregates[level_n_lookup], lookup_parts[n:]
return False, () return False, ()

View File

@ -81,7 +81,7 @@ class Lookup(object):
raise NotImplementedError raise NotImplementedError
class DjangoLookup(Lookup): class BuiltinLookup(Lookup):
def as_sql(self, qn, connection): def as_sql(self, qn, connection):
lhs_sql, params = self.process_lhs(qn, connection) lhs_sql, params = self.process_lhs(qn, connection)
field_internal_type = self.lhs.output_type.get_internal_type() field_internal_type = self.lhs.output_type.get_internal_type()
@ -100,47 +100,47 @@ class DjangoLookup(Lookup):
default_lookups = {} default_lookups = {}
class Exact(DjangoLookup): class Exact(BuiltinLookup):
lookup_name = 'exact' lookup_name = 'exact'
default_lookups['exact'] = Exact default_lookups['exact'] = Exact
class IExact(DjangoLookup): class IExact(BuiltinLookup):
lookup_name = 'iexact' lookup_name = 'iexact'
default_lookups['iexact'] = IExact default_lookups['iexact'] = IExact
class Contains(DjangoLookup): class Contains(BuiltinLookup):
lookup_name = 'contains' lookup_name = 'contains'
default_lookups['contains'] = Contains default_lookups['contains'] = Contains
class IContains(DjangoLookup): class IContains(BuiltinLookup):
lookup_name = 'icontains' lookup_name = 'icontains'
default_lookups['icontains'] = IContains default_lookups['icontains'] = IContains
class GreaterThan(DjangoLookup): class GreaterThan(BuiltinLookup):
lookup_name = 'gt' lookup_name = 'gt'
default_lookups['gt'] = GreaterThan default_lookups['gt'] = GreaterThan
class GreaterThanOrEqual(DjangoLookup): class GreaterThanOrEqual(BuiltinLookup):
lookup_name = 'gte' lookup_name = 'gte'
default_lookups['gte'] = GreaterThanOrEqual default_lookups['gte'] = GreaterThanOrEqual
class LessThan(DjangoLookup): class LessThan(BuiltinLookup):
lookup_name = 'lt' lookup_name = 'lt'
default_lookups['lt'] = LessThan default_lookups['lt'] = LessThan
class LessThanOrEqual(DjangoLookup): class LessThanOrEqual(BuiltinLookup):
lookup_name = 'lte' lookup_name = 'lte'
default_lookups['lte'] = LessThanOrEqual default_lookups['lte'] = LessThanOrEqual
class In(DjangoLookup): class In(BuiltinLookup):
lookup_name = 'in' lookup_name = 'in'
def get_db_prep_lookup(self, value, connection): def get_db_prep_lookup(self, value, connection):
@ -158,27 +158,27 @@ class In(DjangoLookup):
default_lookups['in'] = In default_lookups['in'] = In
class StartsWith(DjangoLookup): class StartsWith(BuiltinLookup):
lookup_name = 'startswith' lookup_name = 'startswith'
default_lookups['startswith'] = StartsWith default_lookups['startswith'] = StartsWith
class IStartsWith(DjangoLookup): class IStartsWith(BuiltinLookup):
lookup_name = 'istartswith' lookup_name = 'istartswith'
default_lookups['istartswith'] = IStartsWith default_lookups['istartswith'] = IStartsWith
class EndsWith(DjangoLookup): class EndsWith(BuiltinLookup):
lookup_name = 'endswith' lookup_name = 'endswith'
default_lookups['endswith'] = EndsWith default_lookups['endswith'] = EndsWith
class IEndsWith(DjangoLookup): class IEndsWith(BuiltinLookup):
lookup_name = 'iendswith' lookup_name = 'iendswith'
default_lookups['iendswith'] = IEndsWith default_lookups['iendswith'] = IEndsWith
class Between(DjangoLookup): class Between(BuiltinLookup):
def get_rhs_op(self, connection, rhs): def get_rhs_op(self, connection, rhs):
return "BETWEEN %s AND %s" % (rhs, rhs) return "BETWEEN %s AND %s" % (rhs, rhs)
@ -193,7 +193,7 @@ class Range(Between):
default_lookups['range'] = Range default_lookups['range'] = Range
class DateLookup(DjangoLookup): class DateLookup(BuiltinLookup):
def process_lhs(self, qn, connection): def process_lhs(self, qn, connection):
lhs, params = super(DateLookup, self).process_lhs(qn, connection) lhs, params = super(DateLookup, self).process_lhs(qn, connection)
@ -241,7 +241,7 @@ class Second(DateLookup):
default_lookups['second'] = Second default_lookups['second'] = Second
class IsNull(DjangoLookup): class IsNull(BuiltinLookup):
lookup_name = 'isnull' lookup_name = 'isnull'
def as_sql(self, qn, connection): def as_sql(self, qn, connection):
@ -253,16 +253,16 @@ class IsNull(DjangoLookup):
default_lookups['isnull'] = IsNull default_lookups['isnull'] = IsNull
class Search(DjangoLookup): class Search(BuiltinLookup):
lookup_name = 'search' lookup_name = 'search'
default_lookups['search'] = Search default_lookups['search'] = Search
class Regex(DjangoLookup): class Regex(BuiltinLookup):
lookup_name = 'regex' lookup_name = 'regex'
default_lookups['regex'] = Regex default_lookups['regex'] = Regex
class IRegex(DjangoLookup): class IRegex(BuiltinLookup):
lookup_name = 'iregex' lookup_name = 'iregex'
default_lookups['iregex'] = IRegex default_lookups['iregex'] = IRegex