SchemaAlterTableAddColumnEventArgs.php 1.72 KB
Newer Older
1 2
<?php

Michael Moravec's avatar
Michael Moravec committed
3 4
declare(strict_types=1);

5 6
namespace Doctrine\DBAL\Event;

Benjamin Morel's avatar
Benjamin Morel committed
7 8 9
use Doctrine\DBAL\Platforms\AbstractPlatform;
use Doctrine\DBAL\Schema\Column;
use Doctrine\DBAL\Schema\TableDiff;
10
use function array_merge;
11
use function func_get_args;
12
use function is_array;
13 14 15 16

/**
 * Event Arguments used when SQL queries for adding table columns are generated inside Doctrine\DBAL\Platform\*Platform.
 */
jsor's avatar
jsor committed
17
class SchemaAlterTableAddColumnEventArgs extends SchemaEventArgs
18
{
19
    /** @var Column */
20
    private $column;
21

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

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

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

    public function __construct(Column $column, TableDiff $tableDiff, AbstractPlatform $platform)
    {
33 34 35
        $this->column    = $column;
        $this->tableDiff = $tableDiff;
        $this->platform  = $platform;
36 37 38
    }

    /**
39
     * @return Column
40 41 42
     */
    public function getColumn()
    {
43
        return $this->column;
44 45 46
    }

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

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

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

        return $this;
    }

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