mirror of
https://github.com/Seldaek/monolog.git
synced 2025-08-06 13:16:39 +02:00
Merge pull request #248 from birkirb/master
eAccelerator doesn't like anonymous functions.
This commit is contained in:
@@ -24,6 +24,7 @@ class StreamHandler extends AbstractProcessingHandler
|
|||||||
{
|
{
|
||||||
protected $stream;
|
protected $stream;
|
||||||
protected $url;
|
protected $url;
|
||||||
|
private $errorMessage;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $stream
|
* @param string $stream
|
||||||
@@ -60,17 +61,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;
|
$this->errorMessage = null;
|
||||||
set_error_handler(function ($code, $msg) use (&$errorMessage) {
|
set_error_handler(array($this, 'customErrorHandler'));
|
||||||
$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 function customErrorHandler($code, $msg) {
|
||||||
|
$this->errorMessage = preg_replace('{^fopen\(.*?\): }', '', $msg);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user