Вход Регистрация
Файл: system/vendor/illuminate/database/Console/Migrations/MigrateMakeCommand.php
Строк: 159
<?php

namespace IlluminateDatabaseConsoleMigrations;

use 
IlluminateDatabaseMigrationsMigrationCreator;
use 
IlluminateSupportComposer;
use 
IlluminateSupportStr;

class 
MigrateMakeCommand extends BaseCommand
{
    
/**
     * The console command signature.
     *
     * @var string
     */
    
protected $signature 'make:migration {name : The name of the migration}
        {--create= : The table to be created}
        {--table= : The table to migrate}
        {--path= : The location where the migration file should be created}
        {--realpath : Indicate any provided migration file paths are pre-resolved absolute paths}
        {--fullpath : Output the full path of the migration}'
;

    
/**
     * The console command description.
     *
     * @var string
     */
    
protected $description 'Create a new migration file';

    
/**
     * The migration creator instance.
     *
     * @var IlluminateDatabaseMigrationsMigrationCreator
     */
    
protected $creator;

    
/**
     * The Composer instance.
     *
     * @var IlluminateSupportComposer
     */
    
protected $composer;

    
/**
     * Create a new migration install command instance.
     *
     * @param  IlluminateDatabaseMigrationsMigrationCreator  $creator
     * @param  IlluminateSupportComposer  $composer
     * @return void
     */
    
public function __construct(MigrationCreator $creatorComposer $composer)
    {
        
parent::__construct();

        
$this->creator $creator;
        
$this->composer $composer;
    }

    
/**
     * Execute the console command.
     *
     * @return void
     */
    
public function handle()
    {
        
// It's possible for the developer to specify the tables to modify in this
        // schema operation. The developer may also specify if this table needs
        // to be freshly created so we can create the appropriate migrations.
        
$name Str::snake(trim($this->input->getArgument('name')));

        
$table $this->input->getOption('table');

        
$create $this->input->getOption('create') ?: false;

        
// If no table was given as an option but a create option is given then we
        // will use the "create" option as the table name. This allows the devs
        // to pass a table name into this option as a short-cut for creating.
        
if (! $table && is_string($create)) {
            
$table $create;

            
$create true;
        }

        
// Next, we will attempt to guess the table name if this the migration has
        // "create" in the name. This will allow us to provide a convenient way
        // of creating migrations that create new tables for the application.
        
if (! $table) {
            [
$table$create] = TableGuesser::guess($name);
        }

        
// Now we are ready to write the migration out to disk. Once we've written
        // the migration out, we will dump-autoload for the entire framework to
        // make sure that the migrations are registered by the class loaders.
        
$this->writeMigration($name$table$create);

        
$this->composer->dumpAutoloads();
    }

    
/**
     * Write the migration file to disk.
     *
     * @param  string  $name
     * @param  string  $table
     * @param  bool  $create
     * @return string
     */
    
protected function writeMigration($name$table$create)
    {
        
$file $this->creator->create(
            
$name$this->getMigrationPath(), $table$create
        
);

        if (! 
$this->option('fullpath')) {
            
$file pathinfo($filePATHINFO_FILENAME);
        }

        
$this->line("<info>Created Migration:</info> {$file}");
    }

    
/**
     * Get migration path (either specified by '--path' option or default location).
     *
     * @return string
     */
    
protected function getMigrationPath()
    {
        if (! 
is_null($targetPath $this->input->getOption('path'))) {
            return ! 
$this->usingRealPath()
                            ? 
$this->laravel->basePath().'/'.$targetPath
                            
$targetPath;
        }

        return 
parent::getMigrationPath();
    }

    
/**
     * Determine if the given path(s) are pre-resolved "real" paths.
     *
     * @return bool
     */
    
protected function usingRealPath()
    {
        return 
$this->input->hasOption('realpath') && $this->option('realpath');
    }
}
Онлайн: 0
Реклама