Exemple #1
0
def add_codes(areas):
    """Given an iterable of areas, return an iterator of those areas with codes
    and m2m countries attached. We don't use prefetch_related because this can
    use a lot of memory."""
    codes = Code.objects.select_related('type').filter(area__in=areas)
    countries = Area.countries.through.objects.select_related(
        'country').filter(area__in=areas)

    lookup = {}
    lookup_countries = {}
    for code in codes.iterator():
        lookup.setdefault(code.area_id, {})[code.type.code] = code.code
    for m2m in countries.iterator():
        c = m2m.country
        lookup_countries.setdefault(m2m.area_id, []).append({
            'code': c.code,
            'name': c.name
        })

    if isinstance(areas, QuerySet):
        if hasattr(countries, 'sorted_areas'):
            areas = countries.sorted_areas(areas)
        areas = areas.iterator()

    for area in areas:
        area.all_codes = lookup.get(area.id, {})
        area.all_m2m_countries = lookup_countries.get(area.id, [])
        yield area
Exemple #2
0
def add_codes(areas):
    """Given an iterable of areas, return an iterator of those areas with codes
    attached. We don't use prefetch_related because this can use a lot of
    memory."""
    codes = Code.objects.select_related('type').filter(area__in=areas)
    lookup = {}
    for code in codes.iterator():
        lookup.setdefault(code.area_id, {})[code.type.code] = code.code
    if isinstance(areas, QuerySet):
        if hasattr(countries, 'sorted_areas'):
            areas = countries.sorted_areas(areas)
        areas = areas.iterator()
    for area in areas:
        if area.id in lookup:
            area.all_codes = lookup[area.id]
        yield area
Exemple #3
0
def add_codes(areas):
    """Given an iterable of areas, return an iterator of those areas with codes
    and m2m countries attached. We don't use prefetch_related because this can
    use a lot of memory."""
    codes = Code.objects.select_related('type').filter(area__in=areas)
    countries = Area.countries.through.objects.select_related('country').filter(area__in=areas)

    lookup = {}
    lookup_countries = {}
    for code in codes.iterator():
        lookup.setdefault(code.area_id, {})[code.type.code] = code.code
    for m2m in countries.iterator():
        c = m2m.country
        lookup_countries.setdefault(m2m.area_id, []).append({'code': c.code, 'name': c.name})

    if isinstance(areas, QuerySet):
        if hasattr(countries, 'sorted_areas'):
            areas = countries.sorted_areas(areas)
        areas = areas.iterator()

    for area in areas:
        area.all_codes = lookup.get(area.id, {})
        area.all_m2m_countries = lookup_countries.get(area.id, [])
        yield area
Exemple #4
0
def sorted_areas(areas):
    # In here to prevent a circular dependency
    from mapit import countries
    if hasattr(countries, 'sorted_areas'):
        return countries.sorted_areas(areas)
    return list(areas)
Exemple #5
0
def sorted_areas(areas):
    # In here to prevent a circular dependency
    from mapit import countries
    if hasattr(countries, 'sorted_areas'):
        return countries.sorted_areas(areas)
    return list(areas)