Initial Drupal 11 with DDEV setup
This commit is contained in:
		
							
								
								
									
										80
									
								
								vendor/symfony/finder/SplFileInfo.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								vendor/symfony/finder/SplFileInfo.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@ -0,0 +1,80 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
namespace Symfony\Component\Finder;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Extends \SplFileInfo to support relative paths.
 | 
			
		||||
 *
 | 
			
		||||
 * @author Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 */
 | 
			
		||||
class SplFileInfo extends \SplFileInfo
 | 
			
		||||
{
 | 
			
		||||
    /**
 | 
			
		||||
     * @param string $file             The file name
 | 
			
		||||
     * @param string $relativePath     The relative path
 | 
			
		||||
     * @param string $relativePathname The relative path name
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct(
 | 
			
		||||
        string $file,
 | 
			
		||||
        private string $relativePath,
 | 
			
		||||
        private string $relativePathname,
 | 
			
		||||
    ) {
 | 
			
		||||
        parent::__construct($file);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the relative path.
 | 
			
		||||
     *
 | 
			
		||||
     * This path does not contain the file name.
 | 
			
		||||
     */
 | 
			
		||||
    public function getRelativePath(): string
 | 
			
		||||
    {
 | 
			
		||||
        return $this->relativePath;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the relative path name.
 | 
			
		||||
     *
 | 
			
		||||
     * This path contains the file name.
 | 
			
		||||
     */
 | 
			
		||||
    public function getRelativePathname(): string
 | 
			
		||||
    {
 | 
			
		||||
        return $this->relativePathname;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function getFilenameWithoutExtension(): string
 | 
			
		||||
    {
 | 
			
		||||
        $filename = $this->getFilename();
 | 
			
		||||
 | 
			
		||||
        return pathinfo($filename, \PATHINFO_FILENAME);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns the contents of the file.
 | 
			
		||||
     *
 | 
			
		||||
     * @throws \RuntimeException
 | 
			
		||||
     */
 | 
			
		||||
    public function getContents(): string
 | 
			
		||||
    {
 | 
			
		||||
        set_error_handler(function ($type, $msg) use (&$error) { $error = $msg; });
 | 
			
		||||
        try {
 | 
			
		||||
            $content = file_get_contents($this->getPathname());
 | 
			
		||||
        } finally {
 | 
			
		||||
            restore_error_handler();
 | 
			
		||||
        }
 | 
			
		||||
        if (false === $content) {
 | 
			
		||||
            throw new \RuntimeException($error);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return $content;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user