Index: chrome/browser/resources/file_manager/foreground/js/metadata/metadata_cache.js |
diff --git a/chrome/browser/resources/file_manager/foreground/js/metadata/metadata_cache.js b/chrome/browser/resources/file_manager/foreground/js/metadata/metadata_cache.js |
index 75dabec132323901386012c85aa231ec7e35a55c..a2e601b3b3d3f68efadbcd98cfb413acdd3d8dba 100644 |
--- a/chrome/browser/resources/file_manager/foreground/js/metadata/metadata_cache.js |
+++ b/chrome/browser/resources/file_manager/foreground/js/metadata/metadata_cache.js |
@@ -77,6 +77,8 @@ function MetadataCache() { |
this.batchCount_ = 0; |
this.totalCount_ = 0; |
+ this.currentCacheSize_ = 0; |
+ |
/** |
* Time of first get query of the current batch. Items updated later than this |
* will not be evicted. |
@@ -104,9 +106,9 @@ MetadataCache.CHILDREN = 1; |
MetadataCache.DESCENDANTS = 2; |
/** |
- * Minimum number of items in cache to start eviction. |
+ * Margin of the cache size. This amount of caches may be kept in addition. |
*/ |
-MetadataCache.EVICTION_NUMBER = 1000; |
+MetadataCache.EVICTION_THRESHOLD_MARGIN = 500; |
/** |
* @return {MetadataCache!} The cache with all providers. |
@@ -159,6 +161,28 @@ MetadataCache.prototype.isInitialized = function() { |
}; |
/** |
+ * Sets the size of cache. The acutual cache size may be larger than the given |
mtomasz
2014/01/08 08:11:02
nit: actual
yoshiki
2014/01/08 09:04:45
Done.
|
+ * value. |
+ * @param {number} size The cache size to be set. |
+ */ |
+MetadataCache.prototype.setCacheSize = function(size) { |
+ this.currentCacheSize_ = size; |
+ |
+ if (this.totalCount_ > this.currentEvictionThreshold_()) |
+ this.evict_(); |
+}; |
+ |
+/** |
+ * Returns the current threshold to evict caches. When the number of caches |
+ * exceeds this, the cache should be evicted. |
+ * @return {number} Threshold to evict caches. |
+ * @private |
+ */ |
+MetadataCache.prototype.currentEvictionThreshold_ = function() { |
+ return this.currentCacheSize_ * 2 + MetadataCache.EVICTION_THRESHOLD_MARGIN; |
+}; |
+ |
+/** |
* Fetches the metadata, puts it in the cache, and passes to callback. |
* If required metadata is already in the cache, does not fetch it again. |
* @param {string|Entry|Array.<string|Entry>} items The list of entries or |
@@ -456,7 +480,7 @@ MetadataCache.prototype.startBatchUpdates = function() { |
MetadataCache.prototype.endBatchUpdates = function() { |
this.batchCount_--; |
if (this.batchCount_ != 0) return; |
- if (this.totalCount_ > MetadataCache.EVICTION_NUMBER) |
+ if (this.totalCount_ > this.currentEvictionThreshold_()) |
this.evict_(); |
for (var index = 0; index < this.observers_.length; index++) { |
var observer = this.observers_[index]; |
@@ -504,7 +528,7 @@ MetadataCache.prototype.evict_ = function() { |
var toRemove = []; |
// We leave only a half of items, so we will not call evict_ soon again. |
- var desiredCount = Math.round(MetadataCache.EVICTION_NUMBER / 2); |
+ var desiredCount = this.currentEvictionThreshold(); |
var removeCount = this.totalCount_ - desiredCount; |
for (var url in this.cache_) { |
if (this.cache_.hasOwnProperty(url) && |