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:
parent
09dc44ec40
commit
f47332cdff
@ -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';
|
||||
}
|
||||
|
@ -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;
|
||||
|
Loading…
x
Reference in New Issue
Block a user