Revert "Revert "smart_build for buildIndex""

This reverts commit cfb2f55b7a.
This commit is contained in:
czaks 2015-04-02 20:29:43 +02:00
parent 0870acb88e
commit 99706835c2

View File

@ -1493,6 +1493,7 @@ function checkMute() {
function buildIndex($global_api = "yes") { function buildIndex($global_api = "yes") {
global $board, $config, $build_pages; global $board, $config, $build_pages;
if (!$config['smart_build']) {
$pages = getPages(); $pages = getPages();
if (!$config['try_smarter']) if (!$config['try_smarter'])
$antibot = create_antibot($board['uri']); $antibot = create_antibot($board['uri']);
@ -1501,13 +1502,17 @@ function buildIndex($global_api = "yes") {
$api = new Api(); $api = new Api();
$catalog = array(); $catalog = array();
} }
}
for ($page = 1; $page <= $config['max_pages']; $page++) { for ($page = 1; $page <= $config['max_pages']; $page++) {
$filename = $board['dir'] . ($page == 1 ? $config['file_index'] : sprintf($config['file_page'], $page)); $filename = $board['dir'] . ($page == 1 ? $config['file_index'] : sprintf($config['file_page'], $page));
$jsonFilename = $board['dir'] . ($page - 1) . '.json'; // pages should start from 0
if ((!$config['api']['enabled'] || $global_api == "skip") && $config['try_smarter'] && isset($build_pages) if ((!$config['api']['enabled'] || $global_api == "skip" || $config['smart_build']) && $config['try_smarter']
&& !empty($build_pages) && !in_array($page, $build_pages) ) && isset($build_pages) && !empty($build_pages) && !in_array($page, $build_pages) )
continue; continue;
if (!$config['smart_build']) {
$content = index($page); $content = index($page);
if (!$content) if (!$content)
break; break;
@ -1516,7 +1521,6 @@ function buildIndex($global_api = "yes") {
if ($config['api']['enabled']) { if ($config['api']['enabled']) {
$threads = $content['threads']; $threads = $content['threads'];
$json = json_encode($api->translatePage($threads)); $json = json_encode($api->translatePage($threads));
$jsonFilename = $board['dir'] . ($page - 1) . '.json'; // pages should start from 0
file_write($jsonFilename, $json); file_write($jsonFilename, $json);
$catalog[$page-1] = $threads; $catalog[$page-1] = $threads;
@ -1538,8 +1542,13 @@ function buildIndex($global_api = "yes") {
file_write($filename, Element('index.html', $content)); file_write($filename, Element('index.html', $content));
} }
else {
file_unlink($filename);
file_unlink($jsonFilename);
}
}
if ($page < $config['max_pages']) { if (!$config['smart_build'] && $page < $config['max_pages']) {
for (;$page<=$config['max_pages'];$page++) { for (;$page<=$config['max_pages'];$page++) {
$filename = $board['dir'] . ($page==1 ? $config['file_index'] : sprintf($config['file_page'], $page)); $filename = $board['dir'] . ($page==1 ? $config['file_index'] : sprintf($config['file_page'], $page));
file_unlink($filename); file_unlink($filename);
@ -1553,6 +1562,13 @@ function buildIndex($global_api = "yes") {
// json api catalog // json api catalog
if ($config['api']['enabled'] && $global_api != "skip") { if ($config['api']['enabled'] && $global_api != "skip") {
if ($config['smart_build']) {
$jsonFilename = $board['dir'] . 'catalog.json';
file_unlink($jsonFilename);
$jsonFilename = $board['dir'] . 'threads.json';
file_unlink($jsonFilename);
}
else {
$json = json_encode($api->translateCatalog($catalog)); $json = json_encode($api->translateCatalog($catalog));
$jsonFilename = $board['dir'] . 'catalog.json'; $jsonFilename = $board['dir'] . 'catalog.json';
file_write($jsonFilename, $json); file_write($jsonFilename, $json);
@ -1561,6 +1577,7 @@ function buildIndex($global_api = "yes") {
$jsonFilename = $board['dir'] . 'threads.json'; $jsonFilename = $board['dir'] . 'threads.json';
file_write($jsonFilename, $json); file_write($jsonFilename, $json);
} }
}
if ($config['try_smarter']) if ($config['try_smarter'])
$build_pages = array(); $build_pages = array();