diff options
author | Dan McGee <dan@archlinux.org> | 2011-01-12 10:08:29 -0600 |
---|---|---|
committer | Dan McGee <dan@archlinux.org> | 2011-01-18 14:26:38 -0600 |
commit | 9cdc536fffc9e77903892c2b14e9462a6ec94ee5 (patch) | |
tree | 9dd56ad147f38867f63c24a3c79bc28e38fc5cd0 /packages/utils.py | |
parent | ecb24ab66a9d0a03ad021d23d4fa543f8163ef3e (diff) |
Add arch-specific group overview pages
This is easy enough to refactor and support with our current infrastructure
and group-fetching functions.
Signed-off-by: Dan McGee <dan@archlinux.org>
Diffstat (limited to 'packages/utils.py')
-rw-r--r-- | packages/utils.py | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/packages/utils.py b/packages/utils.py index 93d0de79..aaec0ec4 100644 --- a/packages/utils.py +++ b/packages/utils.py @@ -8,7 +8,7 @@ from main.utils import cache_function from .models import PackageGroup @cache_function(300) -def get_group_info(): +def get_group_info(include_arches=None): raw_groups = PackageGroup.objects.values_list( 'name', 'pkg__arch__name').order_by('name').annotate( cnt=Count('pkg'), last_update=Max('pkg__last_update')) @@ -38,10 +38,12 @@ def get_group_info(): new_g['arch'] = arch arch_groups[grp['name']] = new_g - # now transform it back into a sorted list + # now transform it back into a sorted list, including only the specified + # architectures if we got a list groups = [] - for val in group_mapping.itervalues(): - groups.extend(val.itervalues()) + for key, val in group_mapping.iteritems(): + if not include_arches or key in include_arches: + groups.extend(val.itervalues()) return sorted(groups, key=itemgetter('name', 'arch')) class Difference(object): |