PluginDynamic::unescapePhp()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 4
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 1
1
<?php
2
/**
3
 * Copyright (c) 2013-2016
4
 *
5
 * @category  Library
6
 * @package   Dwoo\Plugins\Blocks
7
 * @author    Jordi Boggiano <[email protected]>
8
 * @author    David Sanchez <[email protected]>
9
 * @copyright 2008-2013 Jordi Boggiano
10
 * @copyright 2013-2016 David Sanchez
11
 * @license   http://dwoo.org/LICENSE Modified BSD License
12
 * @version   1.3.0
13
 * @date      2016-09-19
14
 * @link      http://dwoo.org/
15
 */
16
17
namespace Dwoo\Plugins\Blocks;
18
19
use Dwoo\Compiler;
20
use Dwoo\Block\Plugin as BlockPlugin;
21
use Dwoo\ICompilable\Block as ICompilableBlock;
22
use Dwoo\Compilation\Exception as CompilationException;
23
24
/**
25
 * Marks the contents of the block as dynamic. Which means that it will not be cached.
26
 * This software is provided 'as-is', without any express or implied warranty.
27
 * In no event will the authors be held liable for any damages arising from the use of this software.
28
 */
29
class PluginDynamic extends BlockPlugin implements ICompilableBlock
30
{
31
    /**
32
     *
33
     */
34
    public function init()
35
    {
36
    }
37
38
    /**
39
     * @param Compiler $compiler
40
     * @param array    $params
41
     * @param string   $prepend
42
     * @param string   $append
43
     * @param string   $type
44
     *
45
     * @return string
46
     */
47
    public static function preProcessing(Compiler $compiler, array $params, $prepend, $append, $type)
48
    {
49
        return '';
50
    }
51
52
    /**
53
     * @param Compiler $compiler
54
     * @param array    $params
55
     * @param string   $prepend
56
     * @param string   $append
57
     * @param string   $content
58
     *
59
     * @return string
60
     */
61
    public static function postProcessing(Compiler $compiler, array $params, $prepend, $append, $content)
62
    {
63
        try {
64
            $compiler->findBlock('dynamic');
65
66
            return $content;
67
        }
68
        catch (CompilationException $e) {
0 ignored issues
show
Coding Style Comprehensibility introduced by
Consider adding a comment why this CATCH block is empty.
Loading history...
69
        }
70
        $output = Compiler::PHP_OPEN . 'if($doCache) {' . "\n\t" . 'echo \'<dwoo:dynamic_\'.$dynamicId.\'>' . str_replace('\'', '\\\'', $content) . '</dwoo:dynamic_\'.$dynamicId.\'>\';' . "\n} else {\n\t";
71 View Code Duplication
        if (substr($content, 0, strlen(Compiler::PHP_OPEN)) == Compiler::PHP_OPEN) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
72
            $output .= substr($content, strlen(Compiler::PHP_OPEN));
73
        } else {
74
            $output .= Compiler::PHP_CLOSE . $content;
75
        }
76 View Code Duplication
        if (substr($output, - strlen(Compiler::PHP_CLOSE)) == Compiler::PHP_CLOSE) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
77
            $output = substr($output, 0, - strlen(Compiler::PHP_CLOSE));
78
        } else {
79
            $output .= Compiler::PHP_OPEN;
80
        }
81
        $output .= "\n}" . Compiler::PHP_CLOSE;
82
83
        return $output;
84
    }
85
86
    /**
87
     * @param $output
88
     * @param $dynamicId
89
     * @param $compiledFile
90
     *
91
     * @return mixed|string
92
     */
93
    public static function unescape($output, $dynamicId, $compiledFile)
94
    {
95
        $output = preg_replace_callback('/<dwoo:dynamic_(' . $dynamicId . ')>(.+?)<\/dwoo:dynamic_' . $dynamicId . '>/s', array(
96
            'self',
97
            'unescapePhp'
98
        ), $output, - 1, $count);
99
        // re-add the includes on top of the file
100
        if ($count && preg_match('#/\* template head \*/(.+?)/\* end template head \*/#s', file_get_contents($compiledFile), $m)) {
0 ignored issues
show
Bug Best Practice introduced by
The expression $count of type integer|null is loosely compared to true; this is ambiguous if the integer can be zero. You might want to explicitly use !== null instead.

In PHP, under loose comparison (like ==, or !=, or switch conditions), values of different types might be equal.

For integer values, zero is a special case, in particular the following results might be unexpected:

0   == false // true
0   == null  // true
123 == false // false
123 == null  // false

// It is often better to use strict comparison
0 === false // false
0 === null  // false
Loading history...
101
            $output = '<?php ' . $m[1] . ' ?>' . $output;
102
        }
103
104
        return $output;
105
    }
106
107
    /**
108
     * @param $match
109
     *
110
     * @return mixed
111
     */
112
    public static function unescapePhp($match)
113
    {
114
        return preg_replace('{<\?php /\*' . $match[1] . '\*/ echo \'(.+?)\'; \?>}s', '$1', $match[2]);
115
    }
116
}
117