1
0
mirror of https://github.com/vichan-devel/vichan.git synced 2025-01-19 01:24:05 +01:00

Allow queue push to fail gracefully

This commit is contained in:
Zankaria 2024-02-16 15:48:18 +01:00
parent 09dc44ec40
commit f47332cdff
2 changed files with 14 additions and 9 deletions

View File

@ -2924,10 +2924,15 @@ function generation_strategy($fun, $array=array()) { global $config;
_syslog(LOG_ERR, "Could not initialize generate queue, falling back to immediate rebuild strategy");
}
return 'rebuild';
} else {
$queue->push(serialize(array('build', $fun, $array, $action)));
return 'ignore';
}
$ret = $queue->push(serialize(array('build', $fun, $array, $action)));
if ($ret === false) {
if ($config['syslog']) {
_syslog(LOG_ERR, "Could not push item in the queue, falling back to immediate rebuild strategy");
}
return 'rebuild';
}
return 'ignore';
case 'build_on_load':
return 'delete';
}

View File

@ -22,11 +22,11 @@ class Queues {
$this->key = $key;
}
public function push(string $str): Queue {
public function push(string $str): bool {
$this->lock->get_ex();
file_put_contents($this->key . microtime(true), $str);
$ret = file_put_contents($this->key . microtime(true), $str);
$this->lock->free();
return $this;
return $ret !== false;
}
public function pop(int $n = 1): array {
@ -63,8 +63,8 @@ class Queues {
*/
public static function none(): Queue {
return new class() implements Queue {
public function push(string $str): Queue {
return $this;
public function push(string $str): bool {
return true;
}
public function pop(int $n = 1): array {
@ -91,7 +91,7 @@ class Queues {
interface Queue {
// Push a string in the queue.
public function push(string $str): Queue;
public function push(string $str): bool;
// Get a string from the queue.
public function pop(int $n = 1): array;