mirror of
https://github.com/phpbb/phpbb.git
synced 2025-07-03 16:48:52 +00:00
Merge pull request #1683 from EXreaction/ticket/11816
[ticket/11816] Fix define/loop checks in IF statements containing parenthesis
This commit is contained in:
commit
70399fe66d
3 changed files with 14 additions and 5 deletions
|
@ -229,18 +229,18 @@ class phpbb_template_twig_lexer extends Twig_Lexer
|
||||||
{
|
{
|
||||||
$inner = $matches[2];
|
$inner = $matches[2];
|
||||||
// Replace $TEST with definition.TEST
|
// Replace $TEST with definition.TEST
|
||||||
$inner = preg_replace('#\s\$([a-zA-Z_0-9]+)#', ' definition.$1', $inner);
|
$inner = preg_replace('#(\s\(?!?)\$([a-zA-Z_0-9]+)#', '$1definition.$2', $inner);
|
||||||
|
|
||||||
// Replace .foo with loops.foo|length
|
// Replace .foo with loops.foo|length
|
||||||
$inner = preg_replace('#\s\.([a-zA-Z_0-9]+)([^a-zA-Z_0-9\.])#', ' loops.$1|length$2', $inner);
|
$inner = preg_replace('#(\s\(?!?)\.([a-zA-Z_0-9]+)([^a-zA-Z_0-9\.])#', '$1loops.$2|length$3', $inner);
|
||||||
|
|
||||||
// Replace .foo.bar with foo.bar|length
|
// Replace .foo.bar with foo.bar|length
|
||||||
$inner = preg_replace('#\s\.([a-zA-Z_0-9\.]+)([^a-zA-Z_0-9\.])#', ' $1|length$2', $inner);
|
$inner = preg_replace('#(\s\(?!?)\.([a-zA-Z_0-9\.]+)([^a-zA-Z_0-9\.])#', '$1$2|length$3', $inner);
|
||||||
|
|
||||||
return "<!-- {$matches[1]}IF{$inner}-->";
|
return "<!-- {$matches[1]}IF{$inner}-->";
|
||||||
};
|
};
|
||||||
|
|
||||||
return preg_replace_callback('#<!-- (ELSE)?IF((.*?)[\s][\$|\.|!]([^\s]+)(.*?))-->#', $callback, $code);
|
return preg_replace_callback('#<!-- (ELSE)?IF((.*?) \(?!?[\$|\.]([^\s]+)(.*?))-->#', $callback, $code);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -158,7 +158,7 @@ class phpbb_template_template_test extends phpbb_template_template_test_case
|
||||||
array(),
|
array(),
|
||||||
array('test_loop' => array(array(), array(), array(), array(), array(), array(), array()), 'test' => array(array()), 'test.deep' => array(array()), 'test.deep.defines' => array(array())),
|
array('test_loop' => array(array(), array(), array(), array(), array(), array(), array()), 'test' => array(array()), 'test.deep' => array(array()), 'test.deep.defines' => array(array())),
|
||||||
array(),
|
array(),
|
||||||
"xyz\nabc\n\$VALUE == 'abc'abc\nbar\nbar\nabc\ntest!@#$%^&*()_-=+{}[]:;\",<.>/?\n[]|foobar|",
|
"xyz\nabc\n\$VALUE == 'abc'\n(\$VALUE == 'abc')\n!\$DOESNT_EXIST\n(!\$DOESNT_EXIST)\nabc\nbar\nbar\nabc\ntest!@#$%^&*()_-=+{}[]:;\",<.>/?[]|foobar|",
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
'define_advanced.html',
|
'define_advanced.html',
|
||||||
|
|
|
@ -7,6 +7,15 @@ $VALUE != 'abc'
|
||||||
<!-- ELSEIF $VALUE == 'abc' -->
|
<!-- ELSEIF $VALUE == 'abc' -->
|
||||||
$VALUE == 'abc'
|
$VALUE == 'abc'
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
|
<!-- IF ($VALUE == 'abc') -->
|
||||||
|
($VALUE == 'abc')
|
||||||
|
<!-- ENDIF -->
|
||||||
|
<!-- IF !$DOESNT_EXIST -->
|
||||||
|
!$DOESNT_EXIST
|
||||||
|
<!-- ENDIF -->
|
||||||
|
<!-- IF (!$DOESNT_EXIST) -->
|
||||||
|
(!$DOESNT_EXIST)
|
||||||
|
<!-- ENDIF -->
|
||||||
<!-- INCLUDE define_include.html -->
|
<!-- INCLUDE define_include.html -->
|
||||||
{$INCLUDED_VALUE}
|
{$INCLUDED_VALUE}
|
||||||
{$VALUE}
|
{$VALUE}
|
||||||
|
|
Loading…
Add table
Reference in a new issue