File: compiler.defun.php

package info (click to toggle)
movabletype-opensource 5.1.4%2Bdfsg-4%2Bdeb7u3
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 32,996 kB
  • sloc: perl: 197,285; php: 62,405; sh: 166; xml: 117; makefile: 83; sql: 32
file content (92 lines) | stat: -rw-r--r-- 3,516 bytes parent folder | download
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<?php
# Movable Type (r) Open Source (C) 2001-2012 Six Apart, Ltd.
# This program is distributed under the terms of the
# GNU General Public License, version 2.
#
# $Id$

/* create code for a function call */ 
function smarty_compiler_fun($tag_args, &$compiler) { 
    $_attrs = $compiler->_parse_attrs($tag_args); 

    if (!isset($_attrs['name'])) $compiler->_syntax_error("fun: missing name parameter"); 
    $_func_name = $compiler->_dequote($_attrs['name']); 
    $_func = 'smarty_fun_'.$_func_name; 
    $_params = 'array('; 
    $_sep = ''; 
    unset($_attrs['name']); 
    foreach ($_attrs as $_key=>$_value) { 
        $_params .= "$_sep'$_key'=>$_value"; 
        $_sep = ','; 
    } 
    $_params .= ')'; 
    return "$_func(\$this, $_params);"; 
} 

$this->register_compiler_function('fun', 'smarty_compiler_fun'); 


/* create code for a function declaration */ 
function smarty_compiler_defun($tag_args, &$compiler) { 
    $attrs = $compiler->_parse_attrs($tag_args); 
    $func_key = '"' . md5('php-5') . '[[' . md5(uniqid('sucks')) . '";'; 
    array_push($compiler->_tag_stack, array('defun', $attrs, $tag_args, $func_key)); 
    if (!isset($attrs['name'])) $compiler->_syntax_error("defun: missing name parameter"); 

    $func_name = $compiler->_dequote($attrs['name']); 
    $func = 'smarty_fun_'.$func_name; 
    return $func_key . "if (!function_exists('$func')) { function $func(&\$this, \$params) { \$_fun_tpl_vars = \$this->_tpl_vars; \$this->assign(\$params);"; 
} 

/* create code for closing a function definition and calling said function */ 
function smarty_compiler_defun_close($tag_args, &$compiler) { 
    $tag_attrs = $compiler->_parse_attrs($tag_args); 
    list($name, $attrs, $open_tag_args, $func_key) = array_pop($compiler->_tag_stack); 
    if ($name!='defun') $compiler->_syntax_error("unexpected {/defun}"); 
    $result =  " \$this->_tpl_vars = \$_fun_tpl_vars; }} " . $func_key;
    if ( !isset($tag_attrs['fun']) || '0' !== $compiler->_dequote($tag_attrs['fun']) )
        $result .= smarty_compiler_fun($open_tag_args, $compiler); 
    return $result;
} 

$this->register_compiler_function('/defun', 'smarty_compiler_defun_close'); 


/* callback: replace all $this with $smarty */ 
function smarty_replace_fun($match) { 
    $tokens = token_get_all('<?php ' . $match[2]); 
    for ($i=0, $count=count($tokens); $i<$count; $i++) { 
        if (is_array($tokens[$i])) { 
            if ($tokens[$i][0] == T_VARIABLE && $tokens[$i][1] == '$this') { 
                $tokens[$i] = '$smarty'; 
            } else {
                $tokens[$i] = $tokens[$i][1]; 
            } 
        } 
    } 
    $result = implode('', $tokens); 
    $result = preg_replace('/^<\?php/', '', $result);
    return $result;
} 


/* postfilter to squeeze the code to make php5 happy */ 
function smarty_postfilter_defun($source, &$compiler) { 
    $search = '("' . md5('php-5') . '\[\[[0-9a-f]{32}";)'; 
    if ((double)phpversion()>=5.0) { 
        /* filter sourcecode. look for func_keys and replace all $this 
           in-between with $smarty */ 
        while (1) { 
            $new_source = preg_replace_callback('/' . $search . '(.*)\\1/Us', 'smarty_replace_fun', $source); 
            if (strcmp($new_source, $source)==0) break; 
            $source = $new_source; 
        } 
    } else { 
        /* remove func_keys */ 
        $source = preg_replace('/' . $search . '/', '', $source); 
    } 
    return $source; 
} 

$this->register_postfilter('smarty_postfilter_defun');
?>