summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorRobin Appelman <icewind@owncloud.com>2016-01-07 18:13:35 +0100
committerRobin Appelman <icewind@owncloud.com>2016-01-15 15:36:52 +0100
commitddbbe1742fda9b508da5c6369dc2a2d5e19cec95 (patch)
treeb69d7c4e73212e7d08cbf40dd8f66d3b85e537c0 /lib
parentfcec704174a384f93214a1f2b83bed385e763ff6 (diff)
downloadnextcloud-server-ddbbe1742fda9b508da5c6369dc2a2d5e19cec95.tar.gz
nextcloud-server-ddbbe1742fda9b508da5c6369dc2a2d5e19cec95.zip
propagate folder size in the same query for write updates
Diffstat (limited to 'lib')
-rw-r--r--lib/private/files/cache/propagator.php12
-rw-r--r--lib/private/files/cache/scanner.php1
-rw-r--r--lib/private/files/cache/updater.php10
3 files changed, 18 insertions, 5 deletions
diff --git a/lib/private/files/cache/propagator.php b/lib/private/files/cache/propagator.php
index 1e85a2ecc8b..50264e54d44 100644
--- a/lib/private/files/cache/propagator.php
+++ b/lib/private/files/cache/propagator.php
@@ -43,9 +43,10 @@ class Propagator implements IPropagator {
/**
* @param string $internalPath
* @param int $time
- * @return array[] all propagated cache entries
+ * @param int $sizeDifference number of bytes the file has grown
+ * @return array[] all propagated entries
*/
- public function propagateChange($internalPath, $time) {
+ public function propagateChange($internalPath, $time, $sizeDifference = 0) {
$cache = $this->storage->getCache($internalPath);
$parentId = $cache->getParentId($internalPath);
@@ -58,7 +59,12 @@ class Propagator implements IPropagator {
}
$mtime = max($time, $entry['mtime']);
- $cache->update($parentId, ['mtime' => $mtime, 'etag' => $this->storage->getETag($entry['path'])]);
+ if ($entry['size'] === -1) {
+ $newSize = -1;
+ } else {
+ $newSize = $entry['size'] + $sizeDifference;
+ }
+ $cache->update($parentId, ['mtime' => $mtime, 'etag' => $this->storage->getETag($entry['path']), 'size' => $newSize]);
$parentId = $entry['parent'];
}
diff --git a/lib/private/files/cache/scanner.php b/lib/private/files/cache/scanner.php
index 1c50978a2e5..60daa323b4b 100644
--- a/lib/private/files/cache/scanner.php
+++ b/lib/private/files/cache/scanner.php
@@ -198,6 +198,7 @@ class Scanner extends BasicEmitter implements IScanner {
if (!empty($newData)) {
$data['fileid'] = $this->addToCache($file, $newData, $fileId);
}
+ $data['oldSize'] = $cacheData['size'];
// post-emit only if it was a file. By that we avoid counting/treating folders as files
if ($data['mimetype'] !== 'httpd/unix-directory') {
diff --git a/lib/private/files/cache/updater.php b/lib/private/files/cache/updater.php
index 58d8e53cfd1..80ba704883e 100644
--- a/lib/private/files/cache/updater.php
+++ b/lib/private/files/cache/updater.php
@@ -118,9 +118,15 @@ class Updater implements IUpdater {
}
$data = $this->scanner->scan($path, Scanner::SCAN_SHALLOW, -1, false);
+ if (isset($data['oldSize']) && isset($data['size'])) {
+ $sizeDifference = $data['size'] - $data['oldSize'];
+ } else {
+ // scanner didn't provide size info, fallback to full size calculation
+ $sizeDifference = 0;
+ $this->cache->correctFolderSize($path, $data);
+ }
$this->correctParentStorageMtime($path);
- $this->cache->correctFolderSize($path, $data);
- $this->propagator->propagateChange($path, $time);
+ $this->propagator->propagateChange($path, $time, $sizeDifference);
}
/**