Fix xdebug version

This commit is contained in:
Shivam Mathur
2019-09-28 08:49:11 +05:30
parent dcd432d918
commit eaf140ca8b
7 changed files with 136 additions and 36 deletions

View File

@ -57,7 +57,7 @@ function enableExtensionWindows(extension) {
return (`try {
$exist = Test-Path -Path $ext_dir\\php_${extension}.dll
if(!(php -m | findstr -i ${extension}) -and $exist) {
Add-Content C:\\tools\\php\\php.ini "extension=php_${extension}.dll"\n` +
Add-Content C:\\tools\\php\\php.ini "${yield utils.getExtensionPrefix(extension)}=php_${extension}.dll"\n` +
(yield utils.log('Enabled ' + extension, 'win32', 'success')) +
` } elseif(php -m | findstr -i ${extension}) {\n` +
(yield utils.log('Extension ' + extension + ' was already enabled', 'win32', 'success')) +
@ -76,8 +76,8 @@ exports.enableExtensionWindows = enableExtensionWindows;
*/
function enableExtensionUnix(extension, os_version) {
return __awaiter(this, void 0, void 0, function* () {
return (`if [ ! "$(php -m | grep -i ${extension})" ] && [ -e "$ext_dir/${extension}.so" ]; then
echo "extension=${extension}.so" >> 'php -i | grep "Loaded Configuration" | sed -e "s|.*=>\s*||"'\n` +
return (`if [ ! "$(php -m | grep -i ${extension})" ] && [ -e "$ext_dir/php_${extension}.so" ]; then
echo "${yield utils.getExtensionPrefix(extension)}=php_${extension}.so" >> 'php -i | grep "Loaded Configuration" | sed -e "s|.*=>\s*||"'\n` +
(yield utils.log('Enabled ' + extension, os_version, 'success')) +
`;\n elif [ "$(php -m | grep -i ${extension})" ]; then \n` +
(yield utils.log('Extension ' + extension + ' was already enabled', os_version, 'success')) +
@ -102,15 +102,25 @@ function addExtensionDarwin(extension_csv, version) {
script += yield enableExtensionUnix(extension, 'darwin');
switch (yield pecl.checkPECLExtension(extension)) {
case true:
let extension_version = version === '5.6' && extension === 'xdebug'
? 'xdebug-2.5.5'
: extension;
let extension_version = extension;
switch (version + extension) {
case '5.6xdebug':
extension_version = 'xdebug-2.5.5';
break;
case '7.4xdebug':
extension_version = 'xdebug-2.8.0beta2';
break;
case '7.2xdebug':
default:
extension_version = extension;
break;
}
script +=
'if [ ! "$(php -m | grep -i ' +
extension +
')" ]; then sudo pecl install ' +
extension_version +
' >/dev/null 2>&1 && ' +
' >/dev/null 2>&1 && ' +
(yield utils.log('Installed and enabled ' + extension, 'darwin', 'success')) +
' || ' +
(yield utils.log('Could not install ' + extension + ' on PHP' + version, 'darwin', 'error')) +
@ -147,26 +157,36 @@ function addExtensionWindows(extension_csv, version) {
extension = extension.toLowerCase();
// add script to enable extension is already installed along with php
script += yield enableExtensionWindows(extension);
let extension_version = '';
let extension_stability = '';
switch (version) {
case '7.4':
extension_version = 'alpha';
extension_stability = 'beta';
break;
case '7.2':
default:
extension_version = 'stable';
extension_stability = 'stable';
break;
}
switch (yield pecl.checkPECLExtension(extension)) {
case true:
let extension_version = extension;
switch (version + extension) {
case '7.4xdebug':
extension_version = 'xdebug -Version 2.8';
break;
case '7.2xdebug':
default:
extension_version = extension;
break;
}
script +=
'if(!(php -m | findstr -i ' +
extension +
')) { ' +
'try { Install-PhpExtension ' +
extension +
' -MinimumStability ' +
extension_version +
' -MinimumStability ' +
extension_stability +
'\n' +
(yield utils.log('Installed and enabled ' + extension, 'win32', 'success')) +
' } catch [Exception] { ' +
@ -211,10 +231,18 @@ function addExtensionLinux(extension_csv, version) {
version +
'-' +
extension +
' >/dev/null 2>&1 || sudo DEBIAN_FRONTEND=noninteractive apt install -y php-' +
extension +
' >/dev/null 2>&1 && ' +
(yield utils.log('Installed and enabled ' + extension, 'linux', 'success')) +
' || ' +
(yield utils.log('Could not find php' + version + '-' + extension + ' on APT repository', 'linux', 'error')) +
(yield utils.log('Could not find php-' +
extension +
' or php' +
version +
'-' +
extension +
' on APT repository', 'linux', 'error')) +
'; fi\n';
});
});

View File

@ -141,3 +141,17 @@ function log(message, os_version, log_type) {
});
}
exports.log = log;
function getExtensionPrefix(extension) {
return __awaiter(this, void 0, void 0, function* () {
let zend = ['xdebug', 'opcache'];
switch (zend.indexOf(extension)) {
case 0:
case 1:
return 'zend_extension';
case -1:
default:
return 'extension';
}
});
}
exports.getExtensionPrefix = getExtensionPrefix;