Skip to content

Commit

Permalink
[4.x] Revert Stache watcher performance PR (#9448)
Browse files Browse the repository at this point in the history
  • Loading branch information
jasonvarga authored Feb 2, 2024
1 parent 7e7eef3 commit 5c8b65e
Show file tree
Hide file tree
Showing 3 changed files with 4 additions and 36 deletions.
2 changes: 0 additions & 2 deletions src/Stache/Stores/CollectionsStore.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,6 @@

class CollectionsStore extends BasicStore
{
protected $traverseRecursively = false;

public function key()
{
return 'collections';
Expand Down
5 changes: 2 additions & 3 deletions src/Stache/Stores/Store.php
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ abstract class Store
protected $storeIndexes = [];
protected $usedIndexes;
protected $fileChangesHandled = false;
protected $traverseRecursively = true;
protected $paths;
protected $fileItems;
protected $shouldCacheFileItems = false;
Expand Down Expand Up @@ -181,7 +180,7 @@ public function handleFileChanges()
$existing = collect(Cache::get($cacheKey, []));

// Get the files and timestamps from the filesystem right now.
$files = Traverser::filter([$this, 'getItemFilter'])->traverse($this, $this->traverseRecursively);
$files = Traverser::filter([$this, 'getItemFilter'])->traverse($this);

// Cache the files and timestamps, ready for comparisons on the next request.
// We'll do it now since there are multiple early returns coming up.
Expand Down Expand Up @@ -293,7 +292,7 @@ public function paths()
return $this->paths = collect($paths);
}

$files = Traverser::filter([$this, 'getItemFilter'])->traverse($this, $this->traverseRecursively);
$files = Traverser::filter([$this, 'getItemFilter'])->traverse($this);

$fileItems = $files->map(function ($timestamp, $path) {
return [
Expand Down
33 changes: 2 additions & 31 deletions src/Stache/Traverser.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,8 @@

namespace Statamic\Stache;

use DirectoryIterator;
use FilesystemIterator;
use Illuminate\Filesystem\Filesystem;
use RecursiveDirectoryIterator;
use RecursiveIteratorIterator;
use Statamic\Facades\Path;
use Symfony\Component\Finder\SplFileInfo;

class Traverser
{
Expand All @@ -20,7 +15,7 @@ public function __construct(Filesystem $filesystem)
$this->filesystem = $filesystem;
}

public function traverse($store, $recursive = true)
public function traverse($store)
{
if (! $dir = $store->directory()) {
throw new \Exception("Store [{$store->key()}] does not have a directory defined.");
Expand All @@ -32,7 +27,7 @@ public function traverse($store, $recursive = true)
return collect();
}

$files = collect($this->getFiles($dir, $recursive));
$files = collect($this->filesystem->allFiles($dir));

if ($this->filter) {
$files = $files->filter($this->filter);
Expand All @@ -50,28 +45,4 @@ public function filter($filter)

return $this;
}

private function getFiles($dir, $recursive)
{
$files = [];

if ($recursive) {
$iterator = new RecursiveIteratorIterator(
new RecursiveDirectoryIterator($dir, FilesystemIterator::SKIP_DOTS | FilesystemIterator::CURRENT_AS_SELF),
RecursiveIteratorIterator::CHILD_FIRST
);
} else {
$iterator = new DirectoryIterator($dir);
}

foreach ($iterator as $fileInfo) {
if ($fileInfo->isDir() || $fileInfo->getFilename()[0] === '.') {
continue;
}

$files[] = new SplFileInfo($fileInfo->getPathname(), $fileInfo->getPath(), $fileInfo->getFilename());
}

return $files;
}
}

0 comments on commit 5c8b65e

Please sign in to comment.