SchemaAlterTableChangeColumnEventArgs.php 1.72 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\ColumnDiff;
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 changing table columns are generated inside {@link AbstractPlatform}.
15
 */
jsor's avatar
jsor committed
16
class SchemaAlterTableChangeColumnEventArgs extends SchemaEventArgs
17
{
18
    /** @var ColumnDiff */
19
    private $columnDiff;
20

21
    /** @var TableDiff */
22
    private $tableDiff;
23

24
    /** @var AbstractPlatform */
25
    private $platform;
26

27
    /** @var string[] */
28
    private $sql = [];
29 30 31

    public function __construct(ColumnDiff $columnDiff, TableDiff $tableDiff, AbstractPlatform $platform)
    {
32 33 34
        $this->columnDiff = $columnDiff;
        $this->tableDiff  = $tableDiff;
        $this->platform   = $platform;
35 36 37
    }

    /**
38
     * @return ColumnDiff
39 40 41
     */
    public function getColumnDiff()
    {
42
        return $this->columnDiff;
43 44 45
    }

    /**
46
     * @return TableDiff
47 48 49
     */
    public function getTableDiff()
    {
50
        return $this->tableDiff;
51 52 53
    }

    /**
54
     * @return AbstractPlatform
55 56 57
     */
    public function getPlatform()
    {
58
        return $this->platform;
59 60 61
    }

    /**
62 63
     * Passing multiple SQL statements as an array is deprecated. Pass each statement as an individual argument instead.
     *
64
     * @param string|string[] $sql
Benjamin Morel's avatar
Benjamin Morel committed
65
     *
Grégoire Paris's avatar
Grégoire Paris committed
66
     * @return SchemaAlterTableChangeColumnEventArgs
67 68 69
     */
    public function addSql($sql)
    {
70
        $this->sql = array_merge($this->sql, is_array($sql) ? $sql : func_get_args());
71 72 73 74 75

        return $this;
    }

    /**
76
     * @return string[]
77 78 79
     */
    public function getSql()
    {
80
        return $this->sql;
81 82
    }
}