SchemaAlterTableEventArgs.php 1.42 KB
Newer Older
1 2 3 4
<?php

namespace Doctrine\DBAL\Event;

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

/**
 * Event Arguments used when SQL queries for creating tables are generated inside Doctrine\DBAL\Platform\*Platform.
 */
class SchemaAlterTableEventArgs extends SchemaEventArgs
{
16
    /** @var TableDiff */
17
    private $tableDiff;
18

19
    /** @var AbstractPlatform */
20
    private $platform;
21

22
    /** @var string[] */
23
    private $sql = [];
24 25 26

    public function __construct(TableDiff $tableDiff, AbstractPlatform $platform)
    {
27 28
        $this->tableDiff = $tableDiff;
        $this->platform  = $platform;
29 30 31
    }

    /**
32
     * @return TableDiff
33 34 35
     */
    public function getTableDiff()
    {
36
        return $this->tableDiff;
37 38 39
    }

    /**
40
     * @return AbstractPlatform
41 42 43
     */
    public function getPlatform()
    {
44
        return $this->platform;
45 46 47
    }

    /**
48 49
     * Passing multiple SQL statements as an array is deprecated. Pass each statement as an individual argument instead.
     *
50
     * @param string|string[] $sql
Benjamin Morel's avatar
Benjamin Morel committed
51
     *
Grégoire Paris's avatar
Grégoire Paris committed
52
     * @return SchemaAlterTableEventArgs
53 54 55
     */
    public function addSql($sql)
    {
56
        $this->sql = array_merge($this->sql, is_array($sql) ? $sql : func_get_args());
57 58 59 60 61

        return $this;
    }

    /**
62
     * @return string[]
63 64 65
     */
    public function getSql()
    {
66
        return $this->sql;
67 68
    }
}