From 14fe9da803b8cb6ccd443c55063583011d298e46 Mon Sep 17 00:00:00 2001 From: Tim Otten Date: Mon, 19 Aug 2019 20:18:46 -0700 Subject: [PATCH] Bootstrap - If there's a PHP parse error, point out potential issues with PHP version --- src/Bootstrap.php | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/src/Bootstrap.php b/src/Bootstrap.php index 4d82f4f4..3361142f 100644 --- a/src/Bootstrap.php +++ b/src/Bootstrap.php @@ -78,6 +78,8 @@ */ class Bootstrap { + const PHP_RECOMMENDED_MIN = '7.0.0'; + protected static $singleton = NULL; protected $options = array(); @@ -150,7 +152,13 @@ public function boot($options = array()) { case E_ERROR: case E_PARSE: case E_COMPILE_ERROR: - $errMsg = sprintf("\nPHP Error: %s\nat line %s in %s", $last_error['message'], $last_error['line'], $last_error['file']); + $errMsg = sprintf("PHP Error: %s\nat line %s in %s", $last_error['message'], $last_error['line'], $last_error['file']); + // We only warn about PHP version if there's actually a fatal; for older versions of civicrm-core, it would be incorrect for + // cv to start outputting PHP version errors. + if (!version_compare(PHP_VERSION, self::PHP_RECOMMENDED_MIN, '>=')) { + $errMsg .= sprintf("\n\nWARNING: cv recommends PHP %s+ for use with current CiviCRM versions. This command is running PHP %s.", self::PHP_RECOMMENDED_MIN, PHP_VERSION); + } + if ($this->output && is_callable([$this->output, 'getErrorOutput'])) { $this->output->getErrorOutput()->writeln("$errMsg"); }