mirror of
https://github.com/shivammathur/setup-php.git
synced 2025-09-06 12:54:07 +07:00
Allow extensions to be compiled from GitHub sources
This commit is contained in:

committed by
Shivam Mathur

parent
912f27c42c
commit
f42065d568
@ -17,6 +17,22 @@ export async function addExtensionDarwin(
|
||||
const version_extension: string = version + extension;
|
||||
const [ext_name, ext_version]: string[] = extension.split('-');
|
||||
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
||||
|
||||
// Install extensions from a GitHub tarball. This needs to be checked first
|
||||
// as the version may also match the semver check below.
|
||||
const urlMatches = extension.match(/.*-(.*)\/(.*)@(.*)/);
|
||||
if (urlMatches != null) {
|
||||
add_script += await utils.joins(
|
||||
'\nadd_extension_from_github',
|
||||
ext_name,
|
||||
urlMatches[1],
|
||||
urlMatches[2],
|
||||
urlMatches[3],
|
||||
ext_prefix
|
||||
);
|
||||
return;
|
||||
}
|
||||
|
||||
switch (true) {
|
||||
// match :extension
|
||||
case /^:/.test(ext_name):
|
||||
@ -142,6 +158,15 @@ export async function addExtensionWindows(
|
||||
ext_version.replace('stable', '')
|
||||
);
|
||||
break;
|
||||
// match extensions from GitHub. Do this before checking for semver as
|
||||
// the version may match that as well
|
||||
case /.*-(.*)\/(.*)@(.*)/.test(extension):
|
||||
add_script += await utils.getUnsupportedLog(
|
||||
extension,
|
||||
version,
|
||||
'win32'
|
||||
);
|
||||
break;
|
||||
// match semver without state
|
||||
case /.*-\d+\.\d+\.\d+$/.test(version_extension):
|
||||
add_script += await utils.joins(
|
||||
@ -214,6 +239,22 @@ export async function addExtensionLinux(
|
||||
const version_extension: string = version + extension;
|
||||
const [ext_name, ext_version]: string[] = extension.split('-');
|
||||
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
||||
|
||||
// Install extensions from a GitHub tarball. This needs to be checked first
|
||||
// as the version may also match the semver check below.
|
||||
const urlMatches = extension.match(/.*-(.*)\/(.*)@(.*)/);
|
||||
if (urlMatches != null) {
|
||||
add_script += await utils.joins(
|
||||
'\nadd_extension_from_github',
|
||||
ext_name,
|
||||
urlMatches[1],
|
||||
urlMatches[2],
|
||||
urlMatches[3],
|
||||
ext_prefix
|
||||
);
|
||||
return;
|
||||
}
|
||||
|
||||
switch (true) {
|
||||
// Match :extension
|
||||
case /^:/.test(ext_name):
|
||||
|
Reference in New Issue
Block a user