Appending the Paginator tree walker hint, instead of removing all the other hints.
This commit is contained in:
parent
dc2be816a8
commit
90a41fba8b
16
lib/Doctrine/ORM/Tools/Pagination/Paginator.php
Normal file → Executable file
16
lib/Doctrine/ORM/Tools/Pagination/Paginator.php
Normal file → Executable file
@ -134,7 +134,7 @@ class Paginator implements \Countable, \IteratorAggregate
|
|||||||
$countQuery->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, 'Doctrine\ORM\Tools\Pagination\CountOutputWalker');
|
$countQuery->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, 'Doctrine\ORM\Tools\Pagination\CountOutputWalker');
|
||||||
$countQuery->setResultSetMapping($rsm);
|
$countQuery->setResultSetMapping($rsm);
|
||||||
} else {
|
} else {
|
||||||
$countQuery->setHint(Query::HINT_CUSTOM_TREE_WALKERS, array('Doctrine\ORM\Tools\Pagination\CountWalker'));
|
$this->appendTreeWalker($countQuery, 'Doctrine\ORM\Tools\Pagination\CountWalker');
|
||||||
}
|
}
|
||||||
|
|
||||||
$countQuery->setFirstResult(null)->setMaxResults(null);
|
$countQuery->setFirstResult(null)->setMaxResults(null);
|
||||||
@ -165,7 +165,7 @@ class Paginator implements \Countable, \IteratorAggregate
|
|||||||
if ($this->useOutputWalker($subQuery)) {
|
if ($this->useOutputWalker($subQuery)) {
|
||||||
$subQuery->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, 'Doctrine\ORM\Tools\Pagination\LimitSubqueryOutputWalker');
|
$subQuery->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, 'Doctrine\ORM\Tools\Pagination\LimitSubqueryOutputWalker');
|
||||||
} else {
|
} else {
|
||||||
$subQuery->setHint(Query::HINT_CUSTOM_TREE_WALKERS, array('Doctrine\ORM\Tools\Pagination\LimitSubqueryWalker'));
|
$this->appendTreeWalker($subQuery, 'Doctrine\ORM\Tools\Pagination\LimitSubqueryWalker');
|
||||||
}
|
}
|
||||||
|
|
||||||
$subQuery->setFirstResult($offset)->setMaxResults($length);
|
$subQuery->setFirstResult($offset)->setMaxResults($length);
|
||||||
@ -231,4 +231,16 @@ class Paginator implements \Countable, \IteratorAggregate
|
|||||||
|
|
||||||
return $this->useOutputWalkers;
|
return $this->useOutputWalkers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function appendTreeWalker(Query $query, $walkerClass)
|
||||||
|
{
|
||||||
|
$hints = $query->getHint(Query::HINT_CUSTOM_TREE_WALKERS);
|
||||||
|
|
||||||
|
if ($hints === false) {
|
||||||
|
$hints = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
$hints[] = $walkerClass;
|
||||||
|
$query->setHint(Query::HINT_CUSTOM_TREE_WALKERS, $hints);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user