Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x

Factory.php

Same filename in this branch
  1. 11.1.x vendor/phpunit/phpunit/src/Runner/Filter/Factory.php
  2. 11.1.x vendor/sebastian/comparator/src/Factory.php
  3. 11.1.x vendor/phpspec/prophecy/src/Prophecy/Comparator/Factory.php
  4. 11.1.x vendor/composer/composer/src/Composer/Factory.php
  5. 11.1.x vendor/justinrainbow/json-schema/src/JsonSchema/Constraints/Factory.php
  6. 11.1.x vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Factory/Factory.php

Namespace

SebastianBergmann\FileIterator

File

vendor/phpunit/php-file-iterator/src/Factory.php

View source
<?php

declare (strict_types=1);

/*
 * This file is part of phpunit/php-file-iterator.
 *
 * (c) Sebastian Bergmann <sebastian@phpunit.de>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
namespace SebastianBergmann\FileIterator;

use const GLOB_ONLYDIR;
use function array_filter;
use function array_map;
use function array_merge;
use function array_values;
use function glob;
use function is_dir;
use function is_string;
use function realpath;
use AppendIterator;
use FilesystemIterator;
use RecursiveDirectoryIterator;
use RecursiveIteratorIterator;

/**
 * @internal This class is not covered by the backward compatibility promise for phpunit/php-file-iterator
 */
final class Factory {
    
    /**
     * @psalm-param list<non-empty-string>|non-empty-string $paths
     * @psalm-param list<non-empty-string>|string $suffixes
     * @psalm-param list<non-empty-string>|string $prefixes
     * @psalm-param list<non-empty-string> $exclude
     */
    public function getFileIterator(array|string $paths, array|string $suffixes = '', array|string $prefixes = '', array $exclude = []) : AppendIterator {
        if (is_string($paths)) {
            $paths = [
                $paths,
            ];
        }
        $paths = $this->resolveWildcards($paths);
        $exclude = $this->resolveWildcards($exclude);
        if (is_string($prefixes)) {
            if ($prefixes !== '') {
                $prefixes = [
                    $prefixes,
                ];
            }
            else {
                $prefixes = [];
            }
        }
        if (is_string($suffixes)) {
            if ($suffixes !== '') {
                $suffixes = [
                    $suffixes,
                ];
            }
            else {
                $suffixes = [];
            }
        }
        $iterator = new AppendIterator();
        foreach ($paths as $path) {
            if (is_dir($path)) {
                $iterator->append(new Iterator($path, new RecursiveIteratorIterator(new ExcludeIterator(new RecursiveDirectoryIterator($path, FilesystemIterator::FOLLOW_SYMLINKS | FilesystemIterator::SKIP_DOTS), $exclude)), $suffixes, $prefixes));
            }
        }
        return $iterator;
    }
    
    /**
     * @psalm-param list<non-empty-string> $paths
     *
     * @psalm-return list<non-empty-string>
     */
    private function resolveWildcards(array $paths) : array {
        $_paths = [
            [],
        ];
        foreach ($paths as $path) {
            if ($locals = glob($path, GLOB_ONLYDIR)) {
                $_paths[] = array_map('\\realpath', $locals);
            }
            else {
                // @codeCoverageIgnoreStart
                $_paths[] = [
                    realpath($path),
                ];
                // @codeCoverageIgnoreEnd
            }
        }
        return array_values(array_filter(array_merge(...$_paths)));
    }

}

Classes

Title Deprecated Summary
Factory @internal This class is not covered by the backward compatibility promise for phpunit/php-file-iterator

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal