public function DefaultContentScanner::scan in Default Content 8
Returns a list of file objects.
Parameters
string $directory: Absolute path to the directory to search.
Return value
array List of stdClass objects with name and uri properties.
File
- src/
DefaultContentScanner.php, line 24 - Contains \Drupal\defaultcontent\DefaultContentScanner.
Class
- DefaultContentScanner
- A scanner to find YAML files in a given folder.
Namespace
Drupal\defaultcontentCode
public function scan($directory, $ext = 'json') {
// Use Unix paths regardless of platform, skip dot directories, follow
// symlinks (to allow extensions to be linked from elsewhere), and return
// the RecursiveDirectoryIterator instance to have access to getSubPath(),
// since SplFileInfo does not support relative paths.
$flags = \FilesystemIterator::UNIX_PATHS;
$flags |= \FilesystemIterator::SKIP_DOTS;
$flags |= \FilesystemIterator::CURRENT_AS_SELF;
$directory_iterator = new \RecursiveDirectoryIterator($directory, $flags);
$iterator = new \RecursiveIteratorIterator($directory_iterator);
$files = array();
foreach ($iterator as $fileinfo) {
/* @var \SplFileInfo $fileinfo */
// Skip directories and non-json files.
if ($fileinfo
->isDir() || $fileinfo
->getExtension() != $ext) {
continue;
}
// @todo Use a typed class?
$file = new \stdClass();
$file->name = $fileinfo
->getFilename();
$file->uri = $fileinfo
->getPathname();
$files[$file->uri] = $file;
}
return $files;
}