Вход Регистрация
Файл: forsoc.ru/vendor/symfony/http-foundation/Symfony/Component/HttpFoundation/File/File.php
Строк: 208
<?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 SymfonyComponentHttpFoundationFile;

use 
SymfonyComponentHttpFoundationFileExceptionFileException;
use 
SymfonyComponentHttpFoundationFileExceptionFileNotFoundException;
use 
SymfonyComponentHttpFoundationFileMimeTypeMimeTypeGuesser;
use 
SymfonyComponentHttpFoundationFileMimeTypeExtensionGuesser;

/**
 * A file in the file system.
 *
 * @author Bernhard Schussek <bschussek@gmail.com>
 */
class File extends SplFileInfo
{
    
/**
     * Constructs a new file from the given path.
     *
     * @param string $path      The path to the file
     * @param bool   $checkPath Whether to check the path or not
     *
     * @throws FileNotFoundException If the given path is not a file
     */
    
public function __construct($path$checkPath true)
    {
        if (
$checkPath && !is_file($path)) {
            throw new 
FileNotFoundException($path);
        }

        
parent::__construct($path);
    }

    
/**
     * Returns the extension based on the mime type.
     *
     * If the mime type is unknown, returns null.
     *
     * This method uses the mime type as guessed by getMimeType()
     * to guess the file extension.
     *
     * @return string|null The guessed extension or null if it cannot be guessed
     *
     * @see ExtensionGuesser
     * @see getMimeType()
     */
    
public function guessExtension()
    {
        
$type $this->getMimeType();
        
$guesser ExtensionGuesser::getInstance();

        return 
$guesser->guess($type);
    }

    
/**
     * Returns the mime type of the file.
     *
     * The mime type is guessed using a MimeTypeGuesser instance, which uses finfo(),
     * mime_content_type() and the system binary "file" (in this order), depending on
     * which of those are available.
     *
     * @return string|null The guessed mime type (i.e. "application/pdf")
     *
     * @see MimeTypeGuesser
     */
    
public function getMimeType()
    {
        
$guesser MimeTypeGuesser::getInstance();

        return 
$guesser->guess($this->getPathname());
    }

    
/**
     * Returns the extension of the file.
     *
     * SplFileInfo::getExtension() is not available before PHP 5.3.6
     *
     * @return string The extension
     */
    
public function getExtension()
    {
        return 
pathinfo($this->getBasename(), PATHINFO_EXTENSION);
    }

    
/**
     * Moves the file to a new location.
     *
     * @param string $directory The destination folder
     * @param string $name      The new file name
     *
     * @return File A File object representing the new file
     *
     * @throws FileException if the target file could not be created
     */
    
public function move($directory$name null)
    {
        
$target $this->getTargetFile($directory$name);

        if (!@
rename($this->getPathname(), $target)) {
            
$error error_get_last();
            throw new 
FileException(sprintf('Could not move the file "%s" to "%s" (%s)'$this->getPathname(), $targetstrip_tags($error['message'])));
        }

        @
chmod($target0666 & ~umask());

        return 
$target;
    }

    protected function 
getTargetFile($directory$name null)
    {
        if (!
is_dir($directory)) {
            if (
false === @mkdir($directory0777true) && !is_dir($directory)) {
                throw new 
FileException(sprintf('Unable to create the "%s" directory'$directory));
            }
        } elseif (!
is_writable($directory)) {
            throw new 
FileException(sprintf('Unable to write in the "%s" directory'$directory));
        }

        
$target rtrim($directory'/\').DIRECTORY_SEPARATOR.(null === $name ? $this->getBasename() : $this->getName($name));

        return new self($target, false);
    }

    /**
     * Returns locale independent base name of the given path.
     *
     * @param string $name The new file name
     *
     * @return string containing
     */
    protected function getName($name)
    {
        $originalName = str_replace('
\', '/', $name);
        $pos = strrpos($originalName, '
/');
        $originalName = false === $pos ? $originalName : substr($originalName, $pos + 1);

        return $originalName;
    }
}
Онлайн: 0
Реклама