Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(931)

Unified Diff: chrome/common/extensions/docs/server2/memcache_file_system.py

Issue 10828235: Extensions Docs Server: Efficient MemcacheFileSystem (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fixes and comments Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/common/extensions/docs/server2/memcache_file_system.py
diff --git a/chrome/common/extensions/docs/server2/memcache_file_system.py b/chrome/common/extensions/docs/server2/memcache_file_system.py
index c691962207bd5ebca8ed5eb30e3b9d00a4611bd8..efe8a798a15c073cdea15318b528de1df602dcd5 100644
--- a/chrome/common/extensions/docs/server2/memcache_file_system.py
+++ b/chrome/common/extensions/docs/server2/memcache_file_system.py
@@ -14,8 +14,8 @@ class MemcacheFileSystem(FileSystem):
self._memcache = memcache
def Stat(self, path):
- """Stats the directory given, or if a file is given, the file's parent
- directory.
+ """Stats the directory given, or if a file is given, stats the files parent
+ directory to get info about the file.
"""
version = self._memcache.Get(path, memcache.MEMCACHE_FILE_SYSTEM_STAT)
if version is None:
@@ -23,6 +23,11 @@ class MemcacheFileSystem(FileSystem):
self._memcache.Set(path,
stat_info.version,
memcache.MEMCACHE_FILE_SYSTEM_STAT)
+ if stat_info.child_versions is not None:
+ for child_path, child_version in stat_info.child_versions.iteritems():
+ self._memcache.Set(path.rsplit('/', 1)[0] + '/' + child_path,
+ child_version,
+ memcache.MEMCACHE_FILE_SYSTEM_STAT)
else:
stat_info = self.StatInfo(version)
return stat_info
@@ -45,12 +50,15 @@ class MemcacheFileSystem(FileSystem):
uncached.append(path)
continue
result[path] = data
- new_items = self._file_system.Read(uncached, binary=binary).Get()
- for item in new_items:
- version = self.Stat(item).version
- value = new_items[item]
- self._memcache.Set(item,
- (value, version),
- memcache.MEMCACHE_FILE_SYSTEM_READ)
- result[item] = value
+ if uncached:
+ # TODO(cduvall): if there are uncached items we should return an
+ # asynchronous future. http://crbug.com/142013
+ new_items = self._file_system.Read(uncached, binary=binary).Get()
+ for item in new_items:
+ version = self.Stat(item).version
+ value = new_items[item]
+ self._memcache.Set(item,
+ (value, version),
+ memcache.MEMCACHE_FILE_SYSTEM_READ)
+ result[item] = value
return Future(value=result)

Powered by Google App Engine
This is Rietveld 408576698