1
<?php
2
/**
3
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
4
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
5
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
6
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
7
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
8
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
9
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
10
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
11
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
12
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
13
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
14
 *
15
 * This software consists of voluntary contributions made by many individuals
16
 * and is licensed under the LGPL. For more information please see
17
 * <http://phing.info>.
18
 */
19

20
/**
21
 * Extends AnsiColorLogger to display times for each target
22
 *
23
 * @author    Patrick McAndrew <patrick@urg.name>
24
 * @copyright 2013. All rights reserved
25
 * @package   phing.listener
26
 */
27
class TargetLogger extends AnsiColorLogger
28
{
29
    private $targetName = null;
30
    private $targetStartTime;
31

32
    /**
33
     * @param BuildEvent $event
34
     */
35 0
    public function targetStarted(BuildEvent $event)
36
    {
37 0
        parent::targetStarted($event);
38 0
        $target = $event->getTarget();
39 0
        $this->targetName = $target->getName();
40 0
        $this->targetStartTime = Phing::currentTimeMillis();
41
    }
42

43
    /**
44
     * @param BuildEvent $event
45
     */
46 0
    public function targetFinished(BuildEvent $event)
47
    {
48 0
        $msg = PHP_EOL . "Target time: " . self::formatTime(
49 0
            Phing::currentTimeMillis() - $this->targetStartTime
50 0
        ) . PHP_EOL;
51 0
        $event->setMessage($msg, Project::MSG_INFO);
52 0
        $this->messageLogged($event);
53 0
        $this->targetName = null;
54
    }
55
}

Read our documentation on viewing source code .

Loading