77 $class = get_class(
$job );
78 $title =
$job->getTitle();
79 $params =
$job->getParams();
82 ->getBacklinkCache( $title );
83 if ( isset( $params[
'pages'] ) || empty( $params[
'recursive'] ) ) {
87 wfWarn( __METHOD__ .
" called on {$job->getType()} leaf job (explosive recursion)." );
88 } elseif ( isset( $params[
'range'] ) ) {
90 $ranges = $params[
'range'][
'subranges'];
91 $realBSize = $params[
'range'][
'batchSize'];
94 $ranges = $backlinkCache->partition( $params[
'table'], $bSize );
98 $extraParams = $opts[
'params'] ?? [];
102 if ( isset( $ranges[0] ) ) {
103 $start = $ranges[0][0];
104 $end = isset( $ranges[1] ) ? $ranges[1][0] - 1 :
false;
106 $iter = $backlinkCache->getLinkPages( $params[
'table'], $start, $end );
107 $pageSources = iterator_to_array( $iter );
109 foreach ( array_chunk( $pageSources, $cSize ) as $pageBatch ) {
111 foreach ( $pageBatch as $page ) {
112 $pages[$page->getId()] = [ $page->getNamespace(), $page->getDBkey() ];
114 $jobs[] =
new $class(
116 [
'pages' => $pages ] + $extraParams
121 if ( isset( $ranges[1] ) ) {
122 $jobs[] =
new $class(
126 'table' => $params[
'table'],
128 'start' => $ranges[1][0],
129 'end' => $ranges[count( $ranges ) - 1][1],
130 'batchSize' => $realBSize,
131 'subranges' => array_slice( $ranges, 1 )
134 'division' => isset( $params[
'division'] )
135 ? ( $params[
'division'] + 1 )