try:
for rank in range(max(minrank, 4), min(maxrank, 26)):
- self.index(runners.BoundaryRunner(rank))
+ self._index(runners.BoundaryRunner(rank))
finally:
self._close_connections()
try:
for rank in range(max(1, minrank), maxrank):
- self.index(runners.RankRunner(rank))
+ self._index(runners.RankRunner(rank))
if maxrank == 30:
- self.index(runners.RankRunner(0))
- self.index(runners.InterpolationRunner(), 20)
- self.index(runners.RankRunner(30), 20)
+ self._index(runners.RankRunner(0))
+ self._index(runners.InterpolationRunner(), 20)
+ self._index(runners.RankRunner(30), 20)
else:
- self.index(runners.RankRunner(maxrank))
+ self._index(runners.RankRunner(maxrank))
finally:
self._close_connections()
self._setup_connections()
try:
- self.index(runners.PostcodeRunner(), 20)
+ self._index(runners.PostcodeRunner(), 20)
finally:
self._close_connections()
finally:
conn.close()
- def index(self, obj, batch=1):
- """ Index a single rank or table. `obj` describes the SQL to use
+ def _index(self, runner, batch=1):
+ """ Index a single rank or table. `runner` describes the SQL to use
for indexing. `batch` describes the number of objects that
should be processed with a single SQL statement
"""
- LOG.warning("Starting %s (using batch size %s)", obj.name(), batch)
+ LOG.warning("Starting %s (using batch size %s)", runner.name(), batch)
cur = self.conn.cursor()
- cur.execute(obj.sql_count_objects())
+ cur.execute(runner.sql_count_objects())
total_tuples = cur.fetchone()[0]
LOG.debug("Total number of rows: %i", total_tuples)
cur.close()
- progress = ProgressLogger(obj.name(), total_tuples)
+ progress = ProgressLogger(runner.name(), total_tuples)
if total_tuples > 0:
cur = self.conn.cursor(name='places')
- cur.execute(obj.sql_get_objects())
+ cur.execute(runner.sql_get_objects())
next_thread = self.find_free_thread()
while True:
LOG.debug("Processing places: %s", str(places))
thread = next(next_thread)
- thread.perform(obj.sql_index_place(places))
+ thread.perform(runner.sql_index_place(places))
progress.add(len(places))
cur.close()