OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2017 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 | |
6 /** | |
7 * Maximum number of entries whose metadata can be cached. | |
8 * @const {number} | |
9 * @private | |
10 */ | |
11 var MAX_CACHED_METADATA = 10000; | |
fukino
2017/06/01 03:37:46
Name it as MAX_CACHED_METADATA_ as it is private.
tetsui
2017/06/01 04:46:58
Done.
| |
12 | |
13 /** | |
14 * @private {!LRUCache<!Metadata>} | |
15 */ | |
16 var metadataCache = new LRUCache(MAX_CACHED_METADATA); | |
fukino
2017/06/01 03:37:46
ditto
tetsui
2017/06/01 04:46:58
Done.
| |
17 | |
18 /** | |
19 * Returns metadata for the given FileEntry. Uses cached metadata if possible. | |
20 * | |
21 * @param {!FileEntry} entry | |
22 * @return {!Promise.<!Metadata>} | |
23 */ | |
24 function getEntryMetadata(entry) { | |
25 var entryURL = entry.toURL(); | |
26 if (metadataCache.hasKey(entryURL)) { | |
27 return Promise.resolve(metadataCache.get(entryURL)); | |
28 } else { | |
29 return new Promise(function(resolve, reject) { | |
30 entry.getMetadata(function(metadata) { | |
31 metadataCache.put(entryURL, metadata); | |
32 resolve(metadata); | |
33 }, reject); | |
34 }); | |
35 } | |
36 }; | |
OLD | NEW |