SchemaAlterTableEventArgs.php 1.34 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 8
use function array_merge;
use function is_array;
9 10 11 12 13 14

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

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

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

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

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

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

    /**
47
     * @param string|string[] $sql
Benjamin Morel's avatar
Benjamin Morel committed
48
     *
49
     * @return \Doctrine\DBAL\Event\SchemaAlterTableEventArgs
50 51 52 53
     */
    public function addSql($sql)
    {
        if (is_array($sql)) {
54
            $this->sql = array_merge($this->sql, $sql);
55
        } else {
56
            $this->sql[] = $sql;
57 58 59 60 61 62
        }

        return $this;
    }

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