[tor-commits] [metrics-tasks/master] task-6329: group relays while doing the selection

karsten at torproject.org karsten at torproject.org
Tue Aug 7 07:01:42 UTC 2012


commit cb39df4d4011900be387c797bd091f5cf77a388f
Author: delber <delber at riseup.net>
Date:   Thu Aug 2 11:05:43 2012 +0000

    task-6329: group relays while doing the selection
---
 task-6329/tor-relays-stats.py |   46 ++++++++++++++++++++--------------------
 1 files changed, 23 insertions(+), 23 deletions(-)

diff --git a/task-6329/tor-relays-stats.py b/task-6329/tor-relays-stats.py
index da9eb6e..9706d80 100755
--- a/task-6329/tor-relays-stats.py
+++ b/task-6329/tor-relays-stats.py
@@ -111,6 +111,7 @@ class RelayStats(object):
         self._data = None
         self._filters = self._create_filters(options)
         self._get_group = self._get_group_function(options)
+        self._relays = None
 
     @property
     def data(self):
@@ -118,6 +119,22 @@ class RelayStats(object):
             self._data = json.load(file('details.json'))
         return self._data
 
+    @property
+    def relays(self):
+        if self._relays:
+            return self._relays
+
+        self._relays = {}
+        for relay in self.data['relays']:
+            accepted = True
+            for f in self._filters:
+                if not f.accept(relay):
+                    accepted = False
+                    break
+            if accepted:
+                self.add_relay(relay)
+        return self._relays
+
     def _create_filters(self, options):
         filters = []
         if not options.inactive:
@@ -146,26 +163,11 @@ class RelayStats(object):
         else:
             return lambda relay: relay.get('fingerprint')
 
-    def get_relays(self):
-        relays = []
-        for relay in self.data['relays']:
-            accepted = True
-            for f in self._filters:
-                if not f.accept(relay):
-                    accepted = False
-                    break
-            if accepted:
-                relays.append(relay)
-        return relays
-
-    def group_relays(self, relays):
-        grouped_relays = {}
-        for relay in relays:
-            key = self._get_group(relay)
-            if key not in grouped_relays:
-                grouped_relays[key] = []
-            grouped_relays[key].append(relay)
-        return grouped_relays
+    def add_relay(self, relay):
+        key = self._get_group(relay)
+        if key not in self._relays:
+            self._relays[key] = []
+        self._relays[key].append(relay)
 
     def format_and_sort_groups(self, grouped_relays, by_country=False, by_as_number=False, links=False):
         formatted_groups = {}
@@ -304,9 +306,7 @@ if '__main__' == __name__:
         parser.error("Did not find details.json.  Re-run with --download.")
 
     stats = RelayStats(options)
-    relays = stats.get_relays()
-    grouped_relays = stats.group_relays(relays)
-    sorted_groups = stats.format_and_sort_groups(grouped_relays,
+    sorted_groups = stats.format_and_sort_groups(stats.relays,
                     by_country=options.by_country,
                     by_as_number=options.by_as,
                     links=options.links)





More information about the tor-commits mailing list