TableDiff.php 3.59 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
<?php
/*
 *  $Id$
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 * This software consists of voluntary contributions made by many individuals
 * and is licensed under the LGPL. For more information, see
 * <http://www.doctrine-project.org>.
 */

namespace Doctrine\DBAL\Schema;

/**
 * Table Diff
 *
 * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
 * @link    www.doctrine-project.org
 * @copyright Copyright (C) 2005-2009 eZ Systems AS. All rights reserved.
 * @license http://ez.no/licenses/new_bsd New BSD License
 * @since   2.0
 * @version $Revision$
 * @author  Benjamin Eberlei <kontakt@beberlei.de>
 */
class TableDiff
{
37 38 39 40 41 42 43 44 45 46
    /**
     * @var string
     */
    public $name = null;

    /**
     * @var string
     */
    public $newName = false;

47 48 49
    /**
     * All added fields
     *
50
     * @var array(string=>Column)
51
     */
52
    public $addedColumns;
53 54 55 56

    /**
     * All changed fields
     *
57
     * @var array(string=>Column)
58
     */
59
    public $changedColumns = array();
60 61 62 63 64 65

    /**
     * All removed fields
     *
     * @var array(string=>bool)
     */
66
    public $removedColumns = array();
67

68 69 70 71 72 73 74
    /**
     * Columns that are only renamed from key to column instance name.
     *
     * @var array(string=>Column)
     */
    public $renamedColumns = array();

75 76 77
    /**
     * All added indexes
     *
78
     * @var array(string=>Index)
79
     */
80
    public $addedIndexes = array();
81 82 83 84

    /**
     * All changed indexes
     *
85
     * @var array(string=>Index)
86
     */
87
    public $changedIndexes = array();
88 89 90 91 92 93

    /**
     * All removed indexes
     *
     * @var array(string=>bool)
     */
94 95 96 97
    public $removedIndexes = array();

    /**
     * All added foreign key definitions
98
     *
99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
     * @var array
     */
    public $addedForeignKeys = array();

    /**
     * All changed foreign keys
     *
     * @var array
     */
    public $changedForeignKeys = array();

    /**
     * All removed foreign keys
     *
     * @var array
     */
    public $removedForeignKeys = array();
116 117 118 119

    /**
     * Constructs an TableDiff object.
     *
120 121
     * @param array(string=>Column) $addedColumns
     * @param array(string=>Column) $changedColumns
122 123 124 125
     * @param array(string=>bool)   $removedColumns
     * @param array(string=>Index)  $addedIndexes
     * @param array(string=>Index)  $changedIndexes
     * @param array(string=>bool)   $removedIndexes
126
     */
127 128 129
    public function __construct($tableName, $addedColumns = array(),
        $changedColumns = array(), $removedColumns = array(), $addedIndexes = array(),
        $changedIndexes = array(), $removedIndexes = array())
130
    {
131
        $this->name = $tableName;
132 133 134
        $this->addedColumns = $addedColumns;
        $this->changedColumns = $changedColumns;
        $this->removedColumns = $removedColumns;
135 136 137 138 139
        $this->addedIndexes = $addedIndexes;
        $this->changedIndexes = $changedIndexes;
        $this->removedIndexes = $removedIndexes;
    }
}