SchemaCreateTableEventArgs.php 1.88 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\Table;
7

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

/**
13
 * Event Arguments used when SQL queries for creating tables are generated inside {@link AbstractPlatform}.
14 15 16
 */
class SchemaCreateTableEventArgs extends SchemaEventArgs
{
17
    /** @var Table */
18
    private $table;
19

Sergei Morozov's avatar
Sergei Morozov committed
20
    /** @var mixed[][] */
21
    private $columns;
22

23
    /** @var mixed[] */
24
    private $options;
25

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

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

jsor's avatar
jsor committed
32
    /**
Sergei Morozov's avatar
Sergei Morozov committed
33 34
     * @param mixed[][] $columns
     * @param mixed[]   $options
jsor's avatar
jsor committed
35
     */
36
    public function __construct(Table $table, array $columns, array $options, AbstractPlatform $platform)
37
    {
38 39 40 41
        $this->table    = $table;
        $this->columns  = $columns;
        $this->options  = $options;
        $this->platform = $platform;
42 43 44
    }

    /**
45
     * @return Table
46 47 48
     */
    public function getTable()
    {
49
        return $this->table;
50 51
    }

52
    /**
Sergei Morozov's avatar
Sergei Morozov committed
53
     * @return mixed[][]
54 55 56
     */
    public function getColumns()
    {
57
        return $this->columns;
58 59 60
    }

    /**
61
     * @return mixed[]
62 63 64
     */
    public function getOptions()
    {
65
        return $this->options;
66 67
    }

68
    /**
69
     * @return AbstractPlatform
70 71 72
     */
    public function getPlatform()
    {
73
        return $this->platform;
74
    }
jsor's avatar
jsor committed
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 SchemaCreateTableEventArgs
jsor's avatar
jsor committed
82 83 84
     */
    public function addSql($sql)
    {
85
        $this->sql = array_merge($this->sql, is_array($sql) ? $sql : func_get_args());
jsor's avatar
jsor committed
86 87 88 89 90

        return $this;
    }

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