diff options
author | alecpl <alec@alec.pl> | 2008-08-20 06:33:40 +0000 |
---|---|---|
committer | alecpl <alec@alec.pl> | 2008-08-20 06:33:40 +0000 |
commit | 6f488bb55f08d64bbdd5255079a24501e55e6851 (patch) | |
tree | 41dbcad1a01d07e705e6c7aeab82908a37e3fb5b /program | |
parent | b469a195258162a8beadc5a778529aa08a998519 (diff) |
#1485286: don't use /e modifier with preg_replace()
Diffstat (limited to 'program')
-rwxr-xr-x | program/include/rcube_template.php | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/program/include/rcube_template.php b/program/include/rcube_template.php index fb6541153..37929de2d 100755 --- a/program/include/rcube_template.php +++ b/program/include/rcube_template.php @@ -484,7 +484,32 @@ class rcube_template extends rcube_html_page */ private function parse_xml($input) { - return preg_replace('/<roundcube:([-_a-z]+)\s+([^>]+)>/Uie', "\$this->xml_command('\\1', '\\2')", $input); + return preg_replace_callback('/<roundcube:([-_a-z]+)\s+([^>]+)>/Ui', array($this, 'xml_command_callback'), $input); + } + + + /** + * This is a callback function for preg_replace_callback (see #1485286) + * It's only purpose is to reconfigure parameters for xml_command, so that the signature isn't disturbed + */ + private function xml_command_callback($matches) + { + if (isset($matches[2])) { + $str_attrib = $matches[2]; + } else { + $str_attrib = ''; + } + + if (isset($matches[3])) { + $add_attrib = $matches[3]; + } else { + $add_attrib = array(); + } + + $command = $matches[1]; + //matches[0] is the entire matched portion of the string + + return $this->xml_command($command, $str_attrib, $add_attrib); } |