aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/files/cache/legacy.php10
-rw-r--r--lib/files/cache/upgrade.php24
2 files changed, 24 insertions, 10 deletions
diff --git a/lib/files/cache/legacy.php b/lib/files/cache/legacy.php
index ee10a1c1350..33d4b8e7c9f 100644
--- a/lib/files/cache/legacy.php
+++ b/lib/files/cache/legacy.php
@@ -14,6 +14,8 @@ namespace OC\Files\Cache;
class Legacy {
private $user;
+ private $cacheHasItems = null;
+
public function __construct($user) {
$this->user = $user;
}
@@ -34,17 +36,23 @@ class Legacy {
* @return bool
*/
function hasItems() {
+ if (!is_null($this->cacheHasItems)) {
+ return $this->cacheHasItems;
+ }
try {
$query = \OC_DB::prepare('SELECT `id` FROM `*PREFIX*fscache` WHERE `user` = ? LIMIT 1');
} catch (\Exception $e) {
+ $this->cacheHasItems = false;
return false;
}
try {
$result = $query->execute(array($this->user));
} catch (\Exception $e) {
+ $this->cacheHasItems = false;
return false;
}
- return (bool)$result->fetchRow();
+ $this->cacheHasItems = (bool)$result->fetchRow();
+ return $this->cacheHasItems;
}
/**
diff --git a/lib/files/cache/upgrade.php b/lib/files/cache/upgrade.php
index 1032e0a844c..cd9a9e91a8c 100644
--- a/lib/files/cache/upgrade.php
+++ b/lib/files/cache/upgrade.php
@@ -43,15 +43,21 @@ class Upgrade {
$data = $this->getNewData($row);
$this->insert($data);
- $children = $this->legacy->getChildren($data['id']);
- foreach ($children as $child) {
- if ($mode == Scanner::SCAN_SHALLOW) {
- $childData = $this->getNewData($child);
- \OC_Hook::emit('\OC\Files\Cache\Upgrade', 'migrate_path', $child['path']);
- $this->insert($childData);
- } else {
- $this->upgradePath($child['path']);
- }
+ $this->upgradeChilds($data['id'], $mode);
+ }
+ }
+
+ /**
+ * @param int $id
+ */
+ function upgradeChilds($id, $mode = Scanner::SCAN_RECURSIVE) {
+ $children = $this->legacy->getChildren($id);
+ foreach ($children as $child) {
+ $childData = $this->getNewData($child);
+ \OC_Hook::emit('\OC\Files\Cache\Upgrade', 'migrate_path', $child['path']);
+ $this->insert($childData);
+ if ($mode == Scanner::SCAN_RECURSIVE) {
+ $this->upgradeChilds($child['id']);
}
}
}