Support define php extension arg-type in config

This commit is contained in:
crazywhalecc
2026-02-06 16:38:03 +08:00
parent 478b85879f
commit 5c7ab48718
5 changed files with 124 additions and 4 deletions

View File

@@ -0,0 +1,20 @@
<?php
declare(strict_types=1);
namespace Package\Artifact;
use StaticPHP\Attribute\Artifact\AfterSourceExtract;
use StaticPHP\Attribute\PatchDescription;
use StaticPHP\Util\FileSystem;
class gmssl
{
#[AfterSourceExtract('gmssl')]
#[PatchDescription('Patch gmssl hex.c to rename OPENSSL functions to GMSSL')]
public function patch(string $target_path): void
{
FileSystem::replaceFileStr($target_path . '/src/hex.c', 'unsigned char *OPENSSL_hexstr2buf(const char *str, size_t *len)', 'unsigned char *GMSSL_hexstr2buf(const char *str, size_t *len)');
FileSystem::replaceFileStr($target_path . '/src/hex.c', 'OPENSSL_hexchar2int', 'GMSSL_hexchar2int');
}
}

View File

@@ -0,0 +1,22 @@
<?php
declare(strict_types=1);
namespace Package\Artifact;
use StaticPHP\Attribute\Artifact\AfterSourceExtract;
use StaticPHP\Attribute\PatchDescription;
use StaticPHP\Runtime\SystemTarget;
use StaticPHP\Util\SourcePatcher;
use StaticPHP\Util\System\LinuxUtil;
class libaom
{
#[AfterSourceExtract('libaom')]
#[PatchDescription('Patch libaom for Linux Musl distributions - posix implicit declaration')]
public function patch(string $target_path): void
{
spc_skip_if(SystemTarget::getTargetOS() !== 'Linux' || !LinuxUtil::isMuslDist(), 'Only for Linux Musl distros');
SourcePatcher::patchFile('libaom_posix_implict.patch', $target_path);
}
}

View File

@@ -0,0 +1,19 @@
<?php
declare(strict_types=1);
namespace Package\Artifact;
use StaticPHP\Attribute\Artifact\AfterSourceExtract;
use StaticPHP\Attribute\PatchDescription;
use StaticPHP\Util\SourcePatcher;
class pkg_config
{
#[AfterSourceExtract('pkg-config')]
#[PatchDescription('Patch pkg-config for GCC 15 compatibility - __builtin_available issue')]
public function patch(string $target_path): void
{
SourcePatcher::patchFile('pkg-config_gcc15.patch', $target_path);
}
}

View File

@@ -0,0 +1,50 @@
<?php
declare(strict_types=1);
namespace Package\Extension;
use Package\Target\php;
use StaticPHP\Attribute\Package\BeforeStage;
use StaticPHP\Attribute\Package\CustomPhpConfigureArg;
use StaticPHP\Attribute\Package\Extension;
use StaticPHP\Attribute\PatchDescription;
use StaticPHP\Package\PackageBuilder;
#[Extension('openssl')]
class openssl
{
#[BeforeStage('php', [php::class, 'makeForUnix'], 'ext-openssl')]
#[PatchDescription('Patch OpenSSL extension for PHP 8.0 compatibility with OpenSSL 3')]
public function patchBeforeMake(): void
{
// patch openssl3 with php8.0 bug
if (php::getPHPVersionID() < 80100) {
$openssl_c = file_get_contents(SOURCE_PATH . '/php-src/ext/openssl/openssl.c');
$openssl_c = preg_replace('/REGISTER_LONG_CONSTANT\s*\(\s*"OPENSSL_SSLV23_PADDING"\s*.+;/', '', $openssl_c);
file_put_contents(SOURCE_PATH . '/php-src/ext/openssl/openssl.c', $openssl_c);
}
}
#[CustomPhpConfigureArg('Darwin')]
#[CustomPhpConfigureArg('Linux')]
public function getUnixConfigureArg(PackageBuilder $builder, bool $shared = false): string
{
$openssl_dir = php::getPHPVersionID() >= 80400 ? '' : ' --with-openssl-dir=' . BUILD_ROOT_PATH;
$args = '--with-openssl=' . ($shared ? 'shared,' : '') . BUILD_ROOT_PATH . $openssl_dir;
if (php::getPHPVersionID() >= 80500 || (php::getPHPVersionID() >= 80400 && !$builder->getOption('enable-zts'))) {
$args .= ' --with-openssl-argon2 OPENSSL_LIBS="-lz"';
}
return $args;
}
#[CustomPhpConfigureArg('Windows')]
public function getWindowsConfigureArg(PackageBuilder $builder): string
{
$args = '--with-openssl';
if (php::getPHPVersionID() >= 80500 || (php::getPHPVersionID() >= 80400 && !$builder->getOption('enable-zts'))) {
$args .= ' --with-openssl-argon2';
}
return $args;
}
}