Completed
Pull Request — master (#1339)
by José
01:55
created

Intent::addAction()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 4
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 1
1
<?php
2
/**
3
 * Phinx
4
 *
5
 * (The MIT license)
6
 *
7
 * Permission is hereby granted, free of charge, to any person obtaining a copy
8
 * of this software and associated * documentation files (the "Software"), to
9
 * deal in the Software without restriction, including without limitation the
10
 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
11
 * sell copies of the Software, and to permit persons to whom the Software is
12
 * furnished to do so, subject to the following conditions:
13
 *
14
 * The above copyright notice and this permission notice shall be included in
15
 * all copies or substantial portions of the Software.
16
 *
17
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
22
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
23
 * IN THE SOFTWARE.
24
 */
25
namespace Phinx\Db\Plan;
26
27
use Phinx\Db\Action\Action;
28
29
/**
30
 * An intent is a collection of actions for many tables
31
 *
32
 */
33
class Intent
34
{
35
36
    /**
37
     * List of actions to be executed
38
     *
39
     * @var \Phinx\Db\Action\Action[]
40
     */
41
    protected $actions = [];
42
43
    /**
44
     * Adds a new action to the collection
45
     *
46
     * @param Action $action The action to add
47
     * @return void
48
     */
49
    public function addAction(Action $action)
50
    {
51
        $this->actions[] = $action;
52
    }
53
54
    /**
55
     * Returns the full list of actions
56
     *
57
     * @return Action[]
58
     */
59
    public function getActions()
60
    {
61
        return $this->actions;
62
    }
63
64
    /**
65
     * Merges another Intent object with this one
66
     *
67
     * @param Intent $another The other intent to merge in
68
     * @return void
69
     */
70
    public function merge(Intent $another)
71
    {
72
        $this->actions = array_merge($this->actions, $another->getActions());
73
    }
74
}
75