mirror of
https://github.com/phpbb/phpbb.git
synced 2025-05-18 21:39:52 +02:00
Merge branch '3.2.x'
This commit is contained in:
commit
c309b4cd8d
@ -190,20 +190,26 @@ class context
|
|||||||
public function assign_block_vars($blockname, array $vararray)
|
public function assign_block_vars($blockname, array $vararray)
|
||||||
{
|
{
|
||||||
$this->num_rows_is_set = false;
|
$this->num_rows_is_set = false;
|
||||||
if (strpos($blockname, '.') !== false)
|
|
||||||
{
|
// For nested block, $blockcount > 0, for top-level block, $blockcount == 0
|
||||||
// Nested block.
|
|
||||||
$blocks = explode('.', $blockname);
|
$blocks = explode('.', $blockname);
|
||||||
$blockcount = count($blocks) - 1;
|
$blockcount = count($blocks) - 1;
|
||||||
|
|
||||||
$str = &$this->tpldata;
|
$block = &$this->tpldata;
|
||||||
for ($i = 0; $i < $blockcount; $i++)
|
for ($i = 0; $i < $blockcount; $i++)
|
||||||
{
|
{
|
||||||
$str = &$str[$blocks[$i]];
|
$pos = strpos($blocks[$i], '[');
|
||||||
$str = &$str[count($str) - 1];
|
$name = ($pos !== false) ? substr($blocks[$i], 0, $pos) : $blocks[$i];
|
||||||
|
$block = &$block[$name];
|
||||||
|
$index = (!$pos || strpos($blocks[$i], '[]') === $pos) ? (count($block) - 1) : (min((int) substr($blocks[$i], $pos + 1, -1), count($block) - 1));
|
||||||
|
$block = &$block[$index];
|
||||||
}
|
}
|
||||||
|
|
||||||
$s_row_count = isset($str[$blocks[$blockcount]]) ? count($str[$blocks[$blockcount]]) : 0;
|
// $block = &$block[$blocks[$i]]; // Do not traverse the last block as it might be empty
|
||||||
|
$name = $blocks[$i];
|
||||||
|
|
||||||
|
// Assign S_ROW_COUNT and S_ROW_NUM
|
||||||
|
$s_row_count = isset($block[$name]) ? count($block[$name]) : 0;
|
||||||
$vararray['S_ROW_COUNT'] = $vararray['S_ROW_NUM'] = $s_row_count;
|
$vararray['S_ROW_COUNT'] = $vararray['S_ROW_NUM'] = $s_row_count;
|
||||||
|
|
||||||
// Assign S_FIRST_ROW
|
// Assign S_FIRST_ROW
|
||||||
@ -213,46 +219,20 @@ class context
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Assign S_BLOCK_NAME
|
// Assign S_BLOCK_NAME
|
||||||
$vararray['S_BLOCK_NAME'] = $blocks[$blockcount];
|
$vararray['S_BLOCK_NAME'] = $name;
|
||||||
|
|
||||||
// Now the tricky part, we always assign S_LAST_ROW and remove the entry before
|
// Now the tricky part, we always assign S_LAST_ROW and remove the entry before
|
||||||
// This is much more clever than going through the complete template data on display (phew)
|
// This is much more clever than going through the complete template data on display (phew)
|
||||||
$vararray['S_LAST_ROW'] = true;
|
$vararray['S_LAST_ROW'] = true;
|
||||||
if ($s_row_count > 0)
|
if ($s_row_count > 0)
|
||||||
{
|
{
|
||||||
unset($str[$blocks[$blockcount]][($s_row_count - 1)]['S_LAST_ROW']);
|
unset($block[$name][($s_row_count - 1)]['S_LAST_ROW']);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now we add the block that we're actually assigning to.
|
// Now we add the block that we're actually assigning to.
|
||||||
// We're adding a new iteration to this block with the given
|
// We're adding a new iteration to this block with the given
|
||||||
// variable assignments.
|
// variable assignments.
|
||||||
$str[$blocks[$blockcount]][] = $vararray;
|
$block[$name][] = $vararray;
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Top-level block.
|
|
||||||
$s_row_count = (isset($this->tpldata[$blockname])) ? count($this->tpldata[$blockname]) : 0;
|
|
||||||
$vararray['S_ROW_COUNT'] = $vararray['S_ROW_NUM'] = $s_row_count;
|
|
||||||
|
|
||||||
// Assign S_FIRST_ROW
|
|
||||||
if (!$s_row_count)
|
|
||||||
{
|
|
||||||
$vararray['S_FIRST_ROW'] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Assign S_BLOCK_NAME
|
|
||||||
$vararray['S_BLOCK_NAME'] = $blockname;
|
|
||||||
|
|
||||||
// We always assign S_LAST_ROW and remove the entry before
|
|
||||||
$vararray['S_LAST_ROW'] = true;
|
|
||||||
if ($s_row_count > 0)
|
|
||||||
{
|
|
||||||
unset($this->tpldata[$blockname][($s_row_count - 1)]['S_LAST_ROW']);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add a new iteration to this block with the variable assignments we were given.
|
|
||||||
$this->tpldata[$blockname][] = $vararray;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -998,6 +998,46 @@ EOT
|
|||||||
$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Deleting by index out of bounds, ignored');
|
$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Deleting by index out of bounds, ignored');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function test_indexed_assign_block_vars()
|
||||||
|
{
|
||||||
|
$this->template->set_filenames(array('test' => 'loop_nested.html'));
|
||||||
|
|
||||||
|
$this->template->assign_var('TEST_MORE', true);
|
||||||
|
|
||||||
|
// @todo Change this
|
||||||
|
$this->template->assign_block_vars('outer', array());
|
||||||
|
$this->template->assign_block_vars('outer.middle', array());
|
||||||
|
$this->template->assign_block_vars('outer', array());
|
||||||
|
$this->template->assign_block_vars('outer.middle', array());
|
||||||
|
$this->template->assign_block_vars('outer.middle', array());
|
||||||
|
$this->template->assign_block_vars('outer', array());
|
||||||
|
$this->template->assign_block_vars('outer.middle', array());
|
||||||
|
$this->template->assign_block_vars('outer.middle', array());
|
||||||
|
$this->template->assign_block_vars('outer.middle', array());
|
||||||
|
|
||||||
|
$expect = 'outer - 0[outer|3]middle - 0[middle|1]outer - 1[outer|3]middle - 0[middle|2]middle - 1[middle|2]outer - 2[outer|3]middle - 0[middle|3]middle - 1[middle|3]middle - 2[middle|3]';
|
||||||
|
$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring template is built correctly before modification');
|
||||||
|
|
||||||
|
$this->template->assign_block_vars('outer[0].middle', array('VARIABLE' => 'test'));
|
||||||
|
|
||||||
|
$expect = 'outer - 0[outer|3]middle - 0[middle|2]middle - 1 - test[middle|2]outer - 1[outer|3]middle - 0[middle|2]middle - 1[middle|2]outer - 2[outer|3]middle - 0[middle|3]middle - 1[middle|3]middle - 2[middle|3]';
|
||||||
|
$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Inserting at the first outer block');
|
||||||
|
|
||||||
|
$this->template->assign_block_vars('outer[1].middle[0].inner', array());
|
||||||
|
|
||||||
|
$expect = 'outer - 0[outer|3]middle - 0[middle|2]middle - 1 - test[middle|2]outer - 1[outer|3]middle - 0[middle|2]inner - 0[inner|1]middle - 1[middle|2]outer - 2[outer|3]middle - 0[middle|3]middle - 1[middle|3]middle - 2[middle|3]';
|
||||||
|
$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Creating an inner block at the first middle block in the second outer block');
|
||||||
|
|
||||||
|
$this->template->assign_block_vars('outer[1].middle[0].inner', array());
|
||||||
|
|
||||||
|
$expect = 'outer - 0[outer|3]middle - 0[middle|2]middle - 1 - test[middle|2]outer - 1[outer|3]middle - 0[middle|2]inner - 0[inner|2]inner - 1[inner|2]middle - 1[middle|2]outer - 2[outer|3]middle - 0[middle|3]middle - 1[middle|3]middle - 2[middle|3]';
|
||||||
|
$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Inserting another inner block in the same place');
|
||||||
|
|
||||||
|
$this->template->assign_block_vars('outer.middle[1].inner', array('VARIABLE' => 'test'));
|
||||||
|
|
||||||
|
$expect = 'outer - 0[outer|3]middle - 0[middle|2]middle - 1 - test[middle|2]outer - 1[outer|3]middle - 0[middle|2]inner - 0[inner|2]inner - 1[inner|2]middle - 1[middle|2]outer - 2[outer|3]middle - 0[middle|3]middle - 1[middle|3]inner - 0 - test[inner|1]middle - 2[middle|3]';
|
||||||
|
$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Inserting another inner block in the same place');
|
||||||
|
}
|
||||||
|
|
||||||
public function assign_block_vars_array_data()
|
public function assign_block_vars_array_data()
|
||||||
{
|
{
|
||||||
|
@ -2,5 +2,8 @@
|
|||||||
outer - {outer.S_ROW_COUNT}<!-- IF outer.VARIABLE --> - {outer.VARIABLE}<!-- ENDIF --><!-- IF TEST_MORE -->[{outer.S_BLOCK_NAME}|{outer.S_NUM_ROWS}]<!-- ENDIF -->
|
outer - {outer.S_ROW_COUNT}<!-- IF outer.VARIABLE --> - {outer.VARIABLE}<!-- ENDIF --><!-- IF TEST_MORE -->[{outer.S_BLOCK_NAME}|{outer.S_NUM_ROWS}]<!-- ENDIF -->
|
||||||
<!-- BEGIN middle -->
|
<!-- BEGIN middle -->
|
||||||
middle - {outer.middle.S_ROW_COUNT}<!-- IF outer.middle.VARIABLE --> - {outer.middle.VARIABLE}<!-- ENDIF --><!-- IF TEST_MORE -->[{outer.middle.S_BLOCK_NAME}|{outer.middle.S_NUM_ROWS}]<!-- ENDIF -->
|
middle - {outer.middle.S_ROW_COUNT}<!-- IF outer.middle.VARIABLE --> - {outer.middle.VARIABLE}<!-- ENDIF --><!-- IF TEST_MORE -->[{outer.middle.S_BLOCK_NAME}|{outer.middle.S_NUM_ROWS}]<!-- ENDIF -->
|
||||||
|
<!-- BEGIN inner -->
|
||||||
|
inner - {outer.middle.inner.S_ROW_COUNT}<!-- IF outer.middle.inner.VARIABLE --> - {outer.middle.inner.VARIABLE}<!-- ENDIF --><!-- IF TEST_MORE -->[{outer.middle.inner.S_BLOCK_NAME}|{outer.middle.inner.S_NUM_ROWS}]<!-- ENDIF -->
|
||||||
|
<!-- END inner -->
|
||||||
<!-- END middle -->
|
<!-- END middle -->
|
||||||
<!-- END outer -->
|
<!-- END outer -->
|
||||||
|
Loading…
x
Reference in New Issue
Block a user