diff options
| author | Adam Tauber <asciimoo@gmail.com> | 2016-11-04 19:38:21 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-11-04 19:38:21 +0100 |
| commit | 51eafdd471fe989accc060f3ebd8efba0d9b6a71 (patch) | |
| tree | c39ce3ba1bdd8d7f02543b11f5f20ea1ade2d0f5 /searx/results.py | |
| parent | 142cd870950e25fe4bb8f4b995b861162af9777c (diff) | |
| parent | 58a6c045c81a84abfb8a29368e7d5453efc5f2fa (diff) | |
Merge pull request #733 from dalf/searchpy
Search architecture
Diffstat (limited to 'searx/results.py')
| -rw-r--r-- | searx/results.py | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/searx/results.py b/searx/results.py index 32832f199..634f71acd 100644 --- a/searx/results.py +++ b/searx/results.py @@ -128,6 +128,8 @@ class ResultContainer(object): self.suggestions = set() self.answers = set() self._number_of_results = [] + self._ordered = False + self.paging = False def extend(self, engine_name, results): for result in list(results): @@ -153,6 +155,9 @@ class ResultContainer(object): self.results[engine_name].extend(results) + if not self.paging and engines[engine_name].paging: + self.paging = True + for i, result in enumerate(results): try: result['url'] = result['url'].decode('utf-8') @@ -219,7 +224,7 @@ class ResultContainer(object): with RLock(): self._merged_results.append(result) - def get_ordered_results(self): + def order_results(self): for result in self._merged_results: score = result_score(result) result['score'] = score @@ -269,8 +274,14 @@ class ResultContainer(object): # update categoryIndex categoryPositions[category] = {'index': len(gresults), 'count': 8} - # return gresults - return gresults + # update _merged_results + self._ordered = True + self._merged_results = gresults + + def get_ordered_results(self): + if not self._ordered: + self.order_results() + return self._merged_results def results_length(self): return len(self._merged_results) |