diff --git a/typo3/sysext/core/Classes/Resource/Driver/LocalDriver.php b/typo3/sysext/core/Classes/Resource/Driver/LocalDriver.php index 1a8c29d73eeca00656d749cf5e96323fd2830590..12418a8c7284d4feb759b4e583cfb4998098cc25 100644 --- a/typo3/sysext/core/Classes/Resource/Driver/LocalDriver.php +++ b/typo3/sysext/core/Classes/Resource/Driver/LocalDriver.php @@ -535,21 +535,26 @@ class LocalDriver extends AbstractHierarchicalFilesystemDriver while ($iterator->valid()) { /** @var $entry \SplFileInfo */ $entry = $iterator->current(); - // skip non-files/non-folders, and empty entries - if ((!$entry->isFile() && !$entry->isDir()) || $entry->getFilename() == '' || - ($entry->isFile() && !$includeFiles) || ($entry->isDir() && !$includeDirs)) { + $isFile = $entry->isFile(); + $isDirectory = $isFile ? false : $entry->isDir(); + if ( + (!$isFile && !$isDirectory) // skip non-files/non-folders + || ($isFile && !$includeFiles) // skip files if they are excluded + || ($isDirectory && !$includeDirs) // skip directories if they are excluded + || $entry->getFilename() === '' // skip empty entries + ) { $iterator->next(); continue; } $entryIdentifier = '/' . substr($entry->getPathname(), $pathLength); $entryName = PathUtility::basename($entryIdentifier); - if ($entry->isDir()) { + if ($isDirectory) { $entryIdentifier .= '/'; } $entryArray = [ 'identifier' => $entryIdentifier, 'name' => $entryName, - 'type' => $entry->isDir() ? 'dir' : 'file' + 'type' => $isDirectory ? 'dir' : 'file' ]; $directoryEntries[$entryIdentifier] = $entryArray; $iterator->next();