1
0
mirror of https://github.com/Seldaek/monolog.git synced 2025-10-23 09:36:11 +02:00

eAccelerator doesn't like anonymous functions.

- Change to private instance method for error handler.
This commit is contained in:
Birkir A. Barkarson
2013-10-10 14:00:41 +09:00
parent f72392d0e6
commit 1f12588c00

View File

@@ -60,17 +60,19 @@ class StreamHandler extends AbstractProcessingHandler
if (!$this->url) { if (!$this->url) {
throw new \LogicException('Missing stream url, the stream can not be opened. This may be caused by a premature call to close().'); throw new \LogicException('Missing stream url, the stream can not be opened. This may be caused by a premature call to close().');
} }
$errorMessage = null; set_error_handler(array($this, 'customErrorHandler'));
set_error_handler(function ($code, $msg) use (&$errorMessage) {
$errorMessage = preg_replace('{^fopen\(.*?\): }', '', $msg);
});
$this->stream = fopen($this->url, 'a'); $this->stream = fopen($this->url, 'a');
restore_error_handler(); restore_error_handler();
if (!is_resource($this->stream)) { if (!is_resource($this->stream)) {
$this->stream = null; $this->stream = null;
throw new \UnexpectedValueException(sprintf('The stream or file "%s" could not be opened: '.$errorMessage, $this->url)); throw new \UnexpectedValueException(sprintf('The stream or file "%s" could not be opened: '.$this->errorMessage, $this->url));
} }
} }
fwrite($this->stream, (string) $record['formatted']); fwrite($this->stream, (string) $record['formatted']);
} }
private $errorMessage = null;
protected function customErrorHandler($code, $msg) {
$this->errorMessage = preg_replace('{^fopen\(.*?\): }', '', $msg);
}
} }