SchemaAlterTableRenameColumnEventArgs.php 1.98 KB
Newer Older
1 2 3 4
<?php

namespace Doctrine\DBAL\Event;

Benjamin Morel's avatar
Benjamin Morel committed
5 6 7
use Doctrine\DBAL\Platforms\AbstractPlatform;
use Doctrine\DBAL\Schema\Column;
use Doctrine\DBAL\Schema\TableDiff;
8

9
use function array_merge;
10
use function func_get_args;
11
use function is_array;
12 13

/**
14
 * Event Arguments used when SQL queries for renaming table columns are generated inside {@link AbstractPlatform}.
15
 */
jsor's avatar
jsor committed
16
class SchemaAlterTableRenameColumnEventArgs extends SchemaEventArgs
17
{
18
    /** @var string */
19
    private $oldColumnName;
20

21
    /** @var Column */
22
    private $column;
23

24
    /** @var TableDiff */
25
    private $tableDiff;
26

27
    /** @var AbstractPlatform */
28
    private $platform;
29

30
    /** @var string[] */
31
    private $sql = [];
32 33

    /**
34
     * @param string $oldColumnName
35 36 37
     */
    public function __construct($oldColumnName, Column $column, TableDiff $tableDiff, AbstractPlatform $platform)
    {
38 39 40 41
        $this->oldColumnName = $oldColumnName;
        $this->column        = $column;
        $this->tableDiff     = $tableDiff;
        $this->platform      = $platform;
42 43 44 45 46 47 48
    }

    /**
     * @return string
     */
    public function getOldColumnName()
    {
49
        return $this->oldColumnName;
50 51 52
    }

    /**
53
     * @return Column
54 55 56
     */
    public function getColumn()
    {
57
        return $this->column;
58 59 60
    }

    /**
61
     * @return TableDiff
62 63 64
     */
    public function getTableDiff()
    {
65
        return $this->tableDiff;
66 67 68
    }

    /**
69
     * @return AbstractPlatform
70 71 72
     */
    public function getPlatform()
    {
73
        return $this->platform;
74 75 76
    }

    /**
77 78
     * Passing multiple SQL statements as an array is deprecated. Pass each statement as an individual argument instead.
     *
79
     * @param string|string[] $sql
Benjamin Morel's avatar
Benjamin Morel committed
80
     *
Grégoire Paris's avatar
Grégoire Paris committed
81
     * @return SchemaAlterTableRenameColumnEventArgs
82 83 84
     */
    public function addSql($sql)
    {
85
        $this->sql = array_merge($this->sql, is_array($sql) ? $sql : func_get_args());
86 87 88 89 90

        return $this;
    }

    /**
91
     * @return string[]
92 93 94
     */
    public function getSql()
    {
95
        return $this->sql;
96 97
    }
}