Skip to content

Commit

Permalink
Merge pull request #298 from overtrue/develop
Browse files Browse the repository at this point in the history
Merge Develop
  • Loading branch information
overtrue committed Feb 22, 2016
2 parents 397ad2b + 6fbd2f7 commit 285e551
Showing 1 changed file with 0 additions and 70 deletions.
70 changes: 0 additions & 70 deletions src/Foundation/Application.php
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@
use Doctrine\Common\Cache\FilesystemCache;
use EasyWeChat\Core\AccessToken;
use EasyWeChat\Support\Log;
use ErrorException;
use Monolog\Handler\NullHandler;
use Monolog\Handler\StreamHandler;
use Monolog\Logger;
Expand Down Expand Up @@ -64,13 +63,6 @@ class Application extends Container
ServiceProviders\BroadcastServiceProvider::class,
];

/**
* The exception handler.
*
* @var callable
*/
protected $exceptionHandler;

/**
* Application constructor.
*
Expand All @@ -91,35 +83,10 @@ public function __construct($config)
$this->registerProviders();
$this->registerBase();
$this->initializeLogger();
$this->registerExceptionHandler();

Log::debug('Current configuration:', $config);
}

/**
* Set the exception handler.
*
* @param callable $callback
*
* @return $this
*/
public function setExceptionHandler(callable $callback)
{
$this->exceptionHandler = $callback;

return $this;
}

/**
* Return current exception handler.
*
* @return callable
*/
public function getExceptionHandler()
{
return $this->exceptionHandler;
}

/**
* Add a provider.
*
Expand Down Expand Up @@ -213,43 +180,6 @@ private function registerBase()
};
}

/**
* Register exception and error handler.
*/
private function registerExceptionHandler()
{
$logTemplate = '%s: %s in %s on line %s.';

$lastExceptionHandler = set_exception_handler(function ($e) use (&$lastExceptionHandler, $logTemplate) {
Log::error(sprintf($logTemplate, $e->getCode(), $e->getMessage(), $e->getFile(), $e->getLine()));

$this->exceptionHandler && call_user_func_array($this->exceptionHandler, [$e]);

if (is_callable($lastExceptionHandler)) {
return call_user_func($lastExceptionHandler, $e);
}
});

$errorHandler = function ($severity, $message, $file, $line) use ($logTemplate) {
Log::error(sprintf($logTemplate, $severity, $message, $file, $line));

if (error_reporting() & $severity) {
throw new ErrorException($message, 0, $severity, $file, $line);
}
};

set_error_handler($errorHandler);

register_shutdown_function(function () use ($errorHandler) {
$lastError = error_get_last();

if ($lastError['type'] === E_ERROR) {
// fatal error
$errorHandler(E_ERROR, $lastError['message'], $lastError['file'], $lastError['line']);
}
});
}

/**
* Initialize logger.
*/
Expand Down

0 comments on commit 285e551

Please sign in to comment.