From 9f5efc3091b57adbe2a87b37e4308c63dfd9e062 Mon Sep 17 00:00:00 2001 From: Markus Staab Date: Tue, 17 Nov 2015 14:31:07 +0100 Subject: [PATCH] added a troubleshooting link in case of out-of-memory errors --- src/Composer/Console/Application.php | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/src/Composer/Console/Application.php b/src/Composer/Console/Application.php index 64df3eab8..465bed37d 100644 --- a/src/Composer/Console/Application.php +++ b/src/Composer/Console/Application.php @@ -56,6 +56,8 @@ class Application extends BaseApplication public function __construct() { + static $shutdownRegistered = false; + if (function_exists('ini_set') && extension_loaded('xdebug')) { ini_set('xdebug.show_exception_trace', false); ini_set('xdebug.scream', false); @@ -64,6 +66,20 @@ class Application extends BaseApplication if (function_exists('date_default_timezone_set') && function_exists('date_default_timezone_get')) { date_default_timezone_set(@date_default_timezone_get()); } + + if (!$shutdownRegistered) { + $shutdownRegistered = true; + + register_shutdown_function(function() { + $lastError = error_get_last(); + + if ($lastError && $lastError['message'] && + (strpos($lastError['message'], 'Allowed memory') !== false /*Zend PHP out of memory error*/ || + strpos($lastError['message'], 'exceeded memory') !== false /*HHVM out of memory errors*/)) { + echo "\n". 'Check https://getcomposer.org/doc/articles/troubleshooting.md#memory-limit-errors for more info on how to handle out of memory errors.'; + } + }); + } parent::__construct('Composer', Composer::VERSION); }