0
0
Fork 1
mirror of https://mau.dev/maunium/synapse.git synced 2024-12-16 18:44:00 +01:00

Merge pull request #3451 from matrix-org/hawkowl/sorteddict-api

Try to not use as much CPU in the cache
This commit is contained in:
Matthew Hodgson 2018-06-26 17:49:55 +01:00 committed by GitHub
commit d91efb06cf
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 4 additions and 2 deletions

0
changelog.d/3447.misc Normal file
View file

View file

@ -78,7 +78,8 @@ class StreamChangeCache(object):
not_known_entities = set(entities) - set(self._entity_to_key) not_known_entities = set(entities) - set(self._entity_to_key)
result = ( result = (
set(self._cache.values()[self._cache.bisect_right(stream_pos) :]) {self._cache[k] for k in self._cache.islice(
start=self._cache.bisect_right(stream_pos))}
.intersection(entities) .intersection(entities)
.union(not_known_entities) .union(not_known_entities)
) )
@ -113,7 +114,8 @@ class StreamChangeCache(object):
assert type(stream_pos) is int assert type(stream_pos) is int
if stream_pos >= self._earliest_known_stream_pos: if stream_pos >= self._earliest_known_stream_pos:
return self._cache.values()[self._cache.bisect_right(stream_pos) :] return [self._cache[k] for k in self._cache.islice(
start=self._cache.bisect_right(stream_pos))]
else: else:
return None return None