Skip to content

Commit

Permalink
Fix foreachelse on arrayiterators
Browse files Browse the repository at this point in the history
Keep track of main loop using a do_else variable.
Fixed #506
  • Loading branch information
wisskid committed Jan 27, 2020
1 parent 97c27a0 commit 388993e
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 3 deletions.
2 changes: 2 additions & 0 deletions change_log.txt
@@ -1,3 +1,5 @@
- fix foreachelse on arrayiterators https://github.com/smarty-php/smarty/issues/506

===== 3.1.34 release ===== 05.11.2019
13.01.2020
- fix typo in exception message (JercSi)
Expand Down
7 changes: 4 additions & 3 deletions libs/sysplugins/smarty_internal_compile_foreach.php
Expand Up @@ -192,7 +192,7 @@ public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler)
$this->openTag(
$compiler,
'foreach',
array('foreach', $compiler->nocache, $local, $itemVar, empty($itemAttr) ? 1 : 2)
array('foreach', $compiler->nocache, $local, $itemVar, empty($itemAttr) ? 0 : 1)
);
// maybe nocache because of nocache variables
$compiler->nocache = $compiler->nocache | $compiler->tag_nocache;
Expand All @@ -219,8 +219,9 @@ public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler)
if (isset($itemAttr[ 'index' ])) {
$output .= "{$itemVar}->index = -1;\n";
}
$output .= "if (\$_from !== null) {\n";
$output .= "{$itemVar}->do_else = true;\n";
$output .= "foreach (\$_from as {$keyTerm}{$itemVar}->value) {\n";
$output .= "{$itemVar}->do_else = false;\n";
if (isset($attributes[ 'key' ]) && isset($itemAttr[ 'key' ])) {
$output .= "\$_smarty_tpl->tpl_vars['{$key}']->value = {$itemVar}->key;\n";
}
Expand Down Expand Up @@ -296,7 +297,7 @@ public function compile($args, Smarty_Internal_TemplateCompilerBase $compiler)
if ($restore === 2) {
$output .= "{$itemVar} = {$local}saved;\n";
}
$output .= "}\n} else {\n?>";
$output .= "}\nif ({$itemVar}->do_else) {\n?>";
return $output;
}
}
Expand Down

0 comments on commit 388993e

Please sign in to comment.