mirror of
https://github.com/crazywhalecc/static-php-cli.git
synced 2026-03-18 21:04:52 +08:00
add env manager
This commit is contained in:
parent
254844b5ec
commit
bd8f91d466
@ -25,7 +25,7 @@ use Symfony\Component\Console\Command\ListCommand;
|
|||||||
*/
|
*/
|
||||||
final class ConsoleApplication extends Application
|
final class ConsoleApplication extends Application
|
||||||
{
|
{
|
||||||
public const VERSION = '2.1.7';
|
public const VERSION = '2.2.0';
|
||||||
|
|
||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
|
|||||||
@ -206,4 +206,9 @@ abstract class LibraryBase
|
|||||||
}
|
}
|
||||||
logger()->debug('enabling ' . static::NAME . " without {$name}");
|
logger()->debug('enabling ' . static::NAME . " without {$name}");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function getSnakeCaseName(): string
|
||||||
|
{
|
||||||
|
return str_replace('-', '_', static::NAME);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -11,68 +11,42 @@ use SPC\exception\RuntimeException;
|
|||||||
use SPC\exception\WrongUsageException;
|
use SPC\exception\WrongUsageException;
|
||||||
use SPC\store\FileSystem;
|
use SPC\store\FileSystem;
|
||||||
use SPC\store\SourcePatcher;
|
use SPC\store\SourcePatcher;
|
||||||
|
use SPC\util\GlobalEnvManager;
|
||||||
|
|
||||||
class LinuxBuilder extends UnixBuilderBase
|
class LinuxBuilder extends UnixBuilderBase
|
||||||
{
|
{
|
||||||
/** @var array Tune cflags */
|
|
||||||
public array $tune_c_flags;
|
|
||||||
|
|
||||||
/** @var bool Micro patch phar flag */
|
/** @var bool Micro patch phar flag */
|
||||||
private bool $phar_patched = false;
|
private bool $phar_patched = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws FileSystemException
|
* @throws FileSystemException
|
||||||
* @throws RuntimeException
|
|
||||||
* @throws WrongUsageException
|
* @throws WrongUsageException
|
||||||
*/
|
*/
|
||||||
public function __construct(array $options = [])
|
public function __construct(array $options = [])
|
||||||
{
|
{
|
||||||
$this->options = $options;
|
$this->options = $options;
|
||||||
|
|
||||||
// ---------- set necessary options ----------
|
// check musl-cross make installed if we use musl-cross-make
|
||||||
// set C/C++ compilers (default: alpine: gcc, others: musl-cross-make)
|
$arch = arch2gnu(php_uname('m'));
|
||||||
if (SystemUtil::isMuslDist()) {
|
if (str_ends_with(getenv('CC'), 'linux-musl-gcc') && !file_exists("/usr/local/musl/bin/{$arch}-linux-musl-gcc")) {
|
||||||
f_putenv("CC={$this->getOption('cc', 'gcc')}");
|
throw new WrongUsageException('musl-cross-make not installed, please install it first. (You can use `doctor` command to install it)');
|
||||||
f_putenv("CXX={$this->getOption('cxx', 'g++')}");
|
|
||||||
f_putenv("AR={$this->getOption('ar', 'ar')}");
|
|
||||||
f_putenv("LD={$this->getOption('ld', 'ld.gold')}");
|
|
||||||
} else {
|
|
||||||
$arch = arch2gnu(php_uname('m'));
|
|
||||||
f_putenv("CC={$this->getOption('cc', "{$arch}-linux-musl-gcc")}");
|
|
||||||
f_putenv("CXX={$this->getOption('cxx', "{$arch}-linux-musl-g++")}");
|
|
||||||
f_putenv("AR={$this->getOption('ar', "{$arch}-linux-musl-ar")}");
|
|
||||||
f_putenv("LD={$this->getOption('ld', 'ld.gold')}");
|
|
||||||
f_putenv("PATH=/usr/local/musl/bin:/usr/local/musl/{$arch}-linux-musl/bin:" . BUILD_ROOT_PATH . '/bin:' . getenv('PATH'));
|
|
||||||
|
|
||||||
// set library path, some libraries need it. (We cannot use `putenv` here, because cmake will be confused)
|
|
||||||
$this->setOptionIfNotExist('library_path', "LIBRARY_PATH=/usr/local/musl/{$arch}-linux-musl/lib");
|
|
||||||
$this->setOptionIfNotExist('ld_library_path', "LD_LIBRARY_PATH=/usr/local/musl/{$arch}-linux-musl/lib");
|
|
||||||
|
|
||||||
// check musl-cross make installed if we use musl-cross-make
|
|
||||||
if (str_ends_with(getenv('CC'), 'linux-musl-gcc') && !file_exists("/usr/local/musl/bin/{$arch}-linux-musl-gcc")) {
|
|
||||||
throw new WrongUsageException('musl-cross-make not installed, please install it first. (You can use `doctor` command to install it)');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// set PKG_CONFIG
|
// set library path, some libraries need it. (We cannot use `putenv` here, because cmake will be confused)
|
||||||
f_putenv('PKG_CONFIG=' . BUILD_ROOT_PATH . '/bin/pkg-config');
|
$this->setOptionIfNotExist('library_path', "LIBRARY_PATH=/usr/local/musl/{$arch}-linux-musl/lib");
|
||||||
// set PKG_CONFIG_PATH
|
$this->setOptionIfNotExist('ld_library_path', "LD_LIBRARY_PATH=/usr/local/musl/{$arch}-linux-musl/lib");
|
||||||
f_putenv('PKG_CONFIG_PATH=' . BUILD_LIB_PATH . '/pkgconfig');
|
|
||||||
|
|
||||||
// set arch (default: current)
|
GlobalEnvManager::init($this);
|
||||||
$this->setOptionIfNotExist('arch', php_uname('m'));
|
|
||||||
$this->setOptionIfNotExist('gnu-arch', arch2gnu($this->getOption('arch')));
|
|
||||||
|
|
||||||
// concurrency
|
// concurrency
|
||||||
$this->concurrency = SystemUtil::getCpuCount();
|
$this->concurrency = intval(getenv('SPC_CONCURRENCY'));
|
||||||
// cflags
|
// cflags
|
||||||
$this->arch_c_flags = SystemUtil::getArchCFlags(getenv('CC'), $this->getOption('arch'));
|
$this->arch_c_flags = getenv('SPC_DEFAULT_C_FLAGS');
|
||||||
$this->arch_cxx_flags = SystemUtil::getArchCFlags(getenv('CXX'), $this->getOption('arch'));
|
$this->arch_cxx_flags = getenv('SPC_DEFAULT_CXX_FLAGS');
|
||||||
$this->tune_c_flags = SystemUtil::checkCCFlags(SystemUtil::getTuneCFlags($this->getOption('arch')), getenv('CC'));
|
|
||||||
// cmake toolchain
|
// cmake toolchain
|
||||||
$this->cmake_toolchain_file = SystemUtil::makeCmakeToolchainFile(
|
$this->cmake_toolchain_file = SystemUtil::makeCmakeToolchainFile(
|
||||||
'Linux',
|
'Linux',
|
||||||
$this->getOption('arch'),
|
$arch,
|
||||||
$this->arch_c_flags,
|
$this->arch_c_flags,
|
||||||
getenv('CC'),
|
getenv('CC'),
|
||||||
getenv('CXX'),
|
getenv('CXX'),
|
||||||
@ -124,8 +98,8 @@ class LinuxBuilder extends UnixBuilderBase
|
|||||||
public function buildPHP(int $build_target = BUILD_TARGET_NONE): void
|
public function buildPHP(int $build_target = BUILD_TARGET_NONE): void
|
||||||
{
|
{
|
||||||
// ---------- Update extra-libs ----------
|
// ---------- Update extra-libs ----------
|
||||||
$extra_libs = $this->getOption('extra-libs', '');
|
$extra_libs = getenv('SPC_EXTRA_LIBS') ?: '';
|
||||||
// non-bloat linking
|
// bloat means force-load all static libraries, even if they are not used
|
||||||
if (!$this->getOption('bloat', false)) {
|
if (!$this->getOption('bloat', false)) {
|
||||||
$extra_libs .= (empty($extra_libs) ? '' : ' ') . implode(' ', $this->getAllStaticLibFiles());
|
$extra_libs .= (empty($extra_libs) ? '' : ' ') . implode(' ', $this->getAllStaticLibFiles());
|
||||||
} else {
|
} else {
|
||||||
@ -133,21 +107,13 @@ class LinuxBuilder extends UnixBuilderBase
|
|||||||
}
|
}
|
||||||
// add libstdc++, some extensions or libraries need it
|
// add libstdc++, some extensions or libraries need it
|
||||||
$extra_libs .= (empty($extra_libs) ? '' : ' ') . ($this->hasCpp() ? '-lstdc++ ' : '');
|
$extra_libs .= (empty($extra_libs) ? '' : ' ') . ($this->hasCpp() ? '-lstdc++ ' : '');
|
||||||
$this->setOption('extra-libs', $extra_libs);
|
f_putenv('SPC_EXTRA_LIBS=' . $extra_libs);
|
||||||
$cflags = $this->arch_c_flags;
|
$cflags = $this->arch_c_flags;
|
||||||
|
|
||||||
// prepare build php envs
|
|
||||||
$envs_build_php = SystemUtil::makeEnvVarString([
|
|
||||||
'CFLAGS' => $cflags,
|
|
||||||
'CPPFLAGS' => '-I' . BUILD_INCLUDE_PATH,
|
|
||||||
'LDFLAGS' => '-L' . BUILD_LIB_PATH,
|
|
||||||
'LIBS' => '-ldl -lpthread',
|
|
||||||
]);
|
|
||||||
|
|
||||||
$this->emitPatchPoint('before-php-buildconf');
|
$this->emitPatchPoint('before-php-buildconf');
|
||||||
SourcePatcher::patchBeforeBuildconf($this);
|
SourcePatcher::patchBeforeBuildconf($this);
|
||||||
|
|
||||||
shell()->cd(SOURCE_PATH . '/php-src')->exec('./buildconf --force');
|
shell()->cd(SOURCE_PATH . '/php-src')->exec(getenv('SPC_CMD_PREFIX_PHP_BUILDCONF'));
|
||||||
|
|
||||||
$this->emitPatchPoint('before-php-configure');
|
$this->emitPatchPoint('before-php-configure');
|
||||||
SourcePatcher::patchBeforeConfigure($this);
|
SourcePatcher::patchBeforeConfigure($this);
|
||||||
@ -169,20 +135,31 @@ class LinuxBuilder extends UnixBuilderBase
|
|||||||
$enableMicro = ($build_target & BUILD_TARGET_MICRO) === BUILD_TARGET_MICRO;
|
$enableMicro = ($build_target & BUILD_TARGET_MICRO) === BUILD_TARGET_MICRO;
|
||||||
$enableEmbed = ($build_target & BUILD_TARGET_EMBED) === BUILD_TARGET_EMBED;
|
$enableEmbed = ($build_target & BUILD_TARGET_EMBED) === BUILD_TARGET_EMBED;
|
||||||
|
|
||||||
|
// prepare build php envs
|
||||||
|
$envs_build_php = SystemUtil::makeEnvVarString([
|
||||||
|
'CFLAGS' => getenv('SPC_CMD_VAR_PHP_CONFIGURE_CFLAGS'),
|
||||||
|
'CPPFLAGS' => getenv('SPC_CMD_VAR_PHP_CONFIGURE_CPPFLAGS'),
|
||||||
|
'LDFLAGS' => getenv('SPC_CMD_VAR_PHP_CONFIGURE_LDFLAGS'),
|
||||||
|
'LIBS' => getenv('SPC_CMD_VAR_PHP_CONFIGURE_LIBS'),
|
||||||
|
]);
|
||||||
|
|
||||||
// upx pack and strip for micro
|
// upx pack and strip for micro
|
||||||
if ($this->getOption('with-upx-pack', false)) {
|
if ($this->getOption('with-upx-pack', false)) {
|
||||||
|
// with upx pack always need strip
|
||||||
FileSystem::replaceFileRegex(
|
FileSystem::replaceFileRegex(
|
||||||
SOURCE_PATH . '/php-src/sapi/micro/Makefile.frag',
|
SOURCE_PATH . '/php-src/sapi/micro/Makefile.frag',
|
||||||
'/POST_MICRO_BUILD_COMMANDS=.*/',
|
'/POST_MICRO_BUILD_COMMANDS=.*/',
|
||||||
'POST_MICRO_BUILD_COMMANDS=\$(STRIP) \$(MICRO_STRIP_FLAGS) \$(SAPI_MICRO_PATH) && ' . $this->getOption('upx-exec') . ' --best \$(SAPI_MICRO_PATH)',
|
'POST_MICRO_BUILD_COMMANDS=\$(STRIP) \$(MICRO_STRIP_FLAGS) \$(SAPI_MICRO_PATH) && ' . getenv('UPX_EXEC') . ' --best \$(SAPI_MICRO_PATH)',
|
||||||
);
|
);
|
||||||
} elseif (!$this->getOption('no-strip', false)) {
|
} elseif (!$this->getOption('no-strip', false)) {
|
||||||
|
// not-no-strip means strip (default behavior)
|
||||||
FileSystem::replaceFileRegex(
|
FileSystem::replaceFileRegex(
|
||||||
SOURCE_PATH . '/php-src/sapi/micro/Makefile.frag',
|
SOURCE_PATH . '/php-src/sapi/micro/Makefile.frag',
|
||||||
'/POST_MICRO_BUILD_COMMANDS=.*/',
|
'/POST_MICRO_BUILD_COMMANDS=.*/',
|
||||||
'POST_MICRO_BUILD_COMMANDS=\$(STRIP) \$(MICRO_STRIP_FLAGS) \$(SAPI_MICRO_PATH)',
|
'POST_MICRO_BUILD_COMMANDS=\$(STRIP) \$(MICRO_STRIP_FLAGS) \$(SAPI_MICRO_PATH)',
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
|
// just no strip
|
||||||
FileSystem::replaceFileRegex(
|
FileSystem::replaceFileRegex(
|
||||||
SOURCE_PATH . '/php-src/sapi/micro/Makefile.frag',
|
SOURCE_PATH . '/php-src/sapi/micro/Makefile.frag',
|
||||||
'/POST_MICRO_BUILD_COMMANDS=.*/',
|
'/POST_MICRO_BUILD_COMMANDS=.*/',
|
||||||
@ -193,14 +170,7 @@ class LinuxBuilder extends UnixBuilderBase
|
|||||||
shell()->cd(SOURCE_PATH . '/php-src')
|
shell()->cd(SOURCE_PATH . '/php-src')
|
||||||
->exec(
|
->exec(
|
||||||
"{$this->getOption('ld_library_path')} " .
|
"{$this->getOption('ld_library_path')} " .
|
||||||
'./configure ' .
|
getenv('SPC_CMD_PREFIX_PHP_CONFIGURE') . ' ' .
|
||||||
'--prefix= ' .
|
|
||||||
'--with-valgrind=no ' .
|
|
||||||
'--enable-shared=no ' .
|
|
||||||
'--enable-static=yes ' .
|
|
||||||
'--disable-all ' .
|
|
||||||
'--disable-cgi ' .
|
|
||||||
'--disable-phpdbg ' .
|
|
||||||
($enableCli ? '--enable-cli ' : '--disable-cli ') .
|
($enableCli ? '--enable-cli ' : '--disable-cli ') .
|
||||||
($enableFpm ? '--enable-fpm ' : '--disable-fpm ') .
|
($enableFpm ? '--enable-fpm ' : '--disable-fpm ') .
|
||||||
($enableEmbed ? '--enable-embed=static ' : '--disable-embed ') .
|
($enableEmbed ? '--enable-embed=static ' : '--disable-embed ') .
|
||||||
@ -252,15 +222,15 @@ class LinuxBuilder extends UnixBuilderBase
|
|||||||
*/
|
*/
|
||||||
protected function buildCli(): void
|
protected function buildCli(): void
|
||||||
{
|
{
|
||||||
$vars = SystemUtil::makeEnvVarString($this->getBuildVars());
|
$vars = SystemUtil::makeEnvVarString($this->getMakeExtraVars());
|
||||||
shell()->cd(SOURCE_PATH . '/php-src')
|
shell()->cd(SOURCE_PATH . '/php-src')
|
||||||
->exec('sed -i "s|//lib|/lib|g" Makefile')
|
->exec('sed -i "s|//lib|/lib|g" Makefile')
|
||||||
->exec("make -j{$this->concurrency} {$vars} cli");
|
->exec("\$SPC_CMD_PREFIX_PHP_MAKE {$vars} cli");
|
||||||
|
|
||||||
if ($this->getOption('with-upx-pack')) {
|
if ($this->getOption('with-upx-pack')) {
|
||||||
shell()->cd(SOURCE_PATH . '/php-src/sapi/cli')
|
shell()->cd(SOURCE_PATH . '/php-src/sapi/cli')
|
||||||
->exec('strip --strip-all php')
|
->exec('strip --strip-all php')
|
||||||
->exec($this->getOption('upx-exec') . ' --best php');
|
->exec(getenv('UPX_EXEC') . ' --best php');
|
||||||
} elseif (!$this->getOption('no-strip', false)) {
|
} elseif (!$this->getOption('no-strip', false)) {
|
||||||
shell()->cd(SOURCE_PATH . '/php-src/sapi/cli')->exec('strip --strip-all php');
|
shell()->cd(SOURCE_PATH . '/php-src/sapi/cli')->exec('strip --strip-all php');
|
||||||
}
|
}
|
||||||
@ -285,12 +255,16 @@ class LinuxBuilder extends UnixBuilderBase
|
|||||||
SourcePatcher::patchMicro(['phar']);
|
SourcePatcher::patchMicro(['phar']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$vars = SystemUtil::makeEnvVarString($this->getBuildVars([
|
$enable_fake_cli = $this->getOption('with-micro-fake-cli', false) ? ' -DPHP_MICRO_FAKE_CLI' : '';
|
||||||
'EXTRA_CFLAGS' => $this->getOption('with-micro-fake-cli', false) ? ' -DPHP_MICRO_FAKE_CLI' : '',
|
$vars = $this->getMakeExtraVars();
|
||||||
]));
|
|
||||||
|
// patch fake cli for micro
|
||||||
|
$vars['EXTRA_CFLAGS'] .= $enable_fake_cli;
|
||||||
|
$vars = SystemUtil::makeEnvVarString($vars);
|
||||||
|
|
||||||
shell()->cd(SOURCE_PATH . '/php-src')
|
shell()->cd(SOURCE_PATH . '/php-src')
|
||||||
->exec('sed -i "s|//lib|/lib|g" Makefile')
|
->exec('sed -i "s|//lib|/lib|g" Makefile')
|
||||||
->exec("make -j{$this->concurrency} {$vars} micro");
|
->exec("\$SPC_CMD_PREFIX_PHP_MAKE {$vars} micro");
|
||||||
|
|
||||||
$this->deployBinary(BUILD_TARGET_MICRO);
|
$this->deployBinary(BUILD_TARGET_MICRO);
|
||||||
|
|
||||||
@ -307,15 +281,15 @@ class LinuxBuilder extends UnixBuilderBase
|
|||||||
*/
|
*/
|
||||||
protected function buildFpm(): void
|
protected function buildFpm(): void
|
||||||
{
|
{
|
||||||
$vars = SystemUtil::makeEnvVarString($this->getBuildVars());
|
$vars = SystemUtil::makeEnvVarString($this->getMakeExtraVars());
|
||||||
shell()->cd(SOURCE_PATH . '/php-src')
|
shell()->cd(SOURCE_PATH . '/php-src')
|
||||||
->exec('sed -i "s|//lib|/lib|g" Makefile')
|
->exec('sed -i "s|//lib|/lib|g" Makefile')
|
||||||
->exec("make -j{$this->concurrency} {$vars} fpm");
|
->exec("\$SPC_CMD_PREFIX_PHP_MAKE {$vars} fpm");
|
||||||
|
|
||||||
if ($this->getOption('with-upx-pack')) {
|
if ($this->getOption('with-upx-pack')) {
|
||||||
shell()->cd(SOURCE_PATH . '/php-src/sapi/fpm')
|
shell()->cd(SOURCE_PATH . '/php-src/sapi/fpm')
|
||||||
->exec('strip --strip-all php-fpm')
|
->exec('strip --strip-all php-fpm')
|
||||||
->exec($this->getOption('upx-exec') . ' --best php-fpm');
|
->exec(getenv('UPX_EXEC') . ' --best php-fpm');
|
||||||
} elseif (!$this->getOption('no-strip', false)) {
|
} elseif (!$this->getOption('no-strip', false)) {
|
||||||
shell()->cd(SOURCE_PATH . '/php-src/sapi/fpm')->exec('strip --strip-all php-fpm');
|
shell()->cd(SOURCE_PATH . '/php-src/sapi/fpm')->exec('strip --strip-all php-fpm');
|
||||||
}
|
}
|
||||||
@ -329,29 +303,19 @@ class LinuxBuilder extends UnixBuilderBase
|
|||||||
*/
|
*/
|
||||||
protected function buildEmbed(): void
|
protected function buildEmbed(): void
|
||||||
{
|
{
|
||||||
$vars = SystemUtil::makeEnvVarString($this->getBuildVars());
|
$vars = SystemUtil::makeEnvVarString($this->getMakeExtraVars());
|
||||||
|
|
||||||
shell()
|
shell()->cd(SOURCE_PATH . '/php-src')
|
||||||
->cd(SOURCE_PATH . '/php-src')
|
|
||||||
->exec('sed -i "s|//lib|/lib|g" Makefile')
|
->exec('sed -i "s|//lib|/lib|g" Makefile')
|
||||||
->exec('make INSTALL_ROOT=' . BUILD_ROOT_PATH . " -j{$this->concurrency} {$vars} install");
|
->exec(getenv('SPC_CMD_PREFIX_PHP_MAKE') . ' INSTALL_ROOT=' . BUILD_ROOT_PATH . " {$vars} install");
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getBuildVars($input = []): array
|
private function getMakeExtraVars(): array
|
||||||
{
|
{
|
||||||
$use_lld = '';
|
|
||||||
if (str_ends_with(getenv('CC'), 'clang') && SystemUtil::findCommand('lld')) {
|
|
||||||
$use_lld = '-Xcompiler -fuse-ld=lld';
|
|
||||||
}
|
|
||||||
$optimization = $this->getOption('no-strip', false) ? '-g -O0' : '-g0 -Os';
|
|
||||||
$cflags = isset($input['EXTRA_CFLAGS']) && $input['EXTRA_CFLAGS'] ? " {$input['EXTRA_CFLAGS']}" : '';
|
|
||||||
$libs = isset($input['EXTRA_LIBS']) && $input['EXTRA_LIBS'] ? " {$input['EXTRA_LIBS']}" : '';
|
|
||||||
$ldflags = isset($input['EXTRA_LDFLAGS_PROGRAM']) && $input['EXTRA_LDFLAGS_PROGRAM'] ? " {$input['EXTRA_LDFLAGS_PROGRAM']}" : '';
|
|
||||||
$tune_c_flags = implode(' ', array_map(fn ($x) => "-Xcompiler {$x}", $this->tune_c_flags));
|
|
||||||
return [
|
return [
|
||||||
'EXTRA_CFLAGS' => "{$optimization} -fno-ident -fPIE {$tune_c_flags}{$cflags}",
|
'EXTRA_CFLAGS' => getenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_CFLAGS'),
|
||||||
'EXTRA_LIBS' => "{$this->getOption('extra-libs', '')} {$libs}",
|
'EXTRA_LIBS' => getenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_LIBS'),
|
||||||
'EXTRA_LDFLAGS_PROGRAM' => "{$use_lld} -all-static{$ldflags}",
|
'EXTRA_LDFLAGS_PROGRAM' => getenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_LDFLAGS_PROGRAM'),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -42,8 +42,7 @@ class openssl extends LinuxLibraryBase
|
|||||||
$extra = '';
|
$extra = '';
|
||||||
$ex_lib = '-ldl -pthread';
|
$ex_lib = '-ldl -pthread';
|
||||||
|
|
||||||
$env = "CFLAGS='{$this->builder->arch_c_flags}'";
|
$env = "CC='" . getenv('CC') . ' -static -idirafter ' . BUILD_INCLUDE_PATH .
|
||||||
$env .= " CC='" . getenv('CC') . ' -static -idirafter ' . BUILD_INCLUDE_PATH .
|
|
||||||
' -idirafter /usr/include/ ' .
|
' -idirafter /usr/include/ ' .
|
||||||
' -idirafter /usr/include/' . $this->builder->getOption('arch') . '-linux-gnu/ ' .
|
' -idirafter /usr/include/' . $this->builder->getOption('arch') . '-linux-gnu/ ' .
|
||||||
"' ";
|
"' ";
|
||||||
@ -64,7 +63,8 @@ class openssl extends LinuxLibraryBase
|
|||||||
$clang_postfix = SystemUtil::getCCType(getenv('CC')) === 'clang' ? '-clang' : '';
|
$clang_postfix = SystemUtil::getCCType(getenv('CC')) === 'clang' ? '-clang' : '';
|
||||||
|
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
->exec(
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags() ?: $this->builder->arch_c_flags, 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
|
->execWithEnv(
|
||||||
"{$env} ./Configure no-shared {$extra} " .
|
"{$env} ./Configure no-shared {$extra} " .
|
||||||
'--prefix=/ ' .
|
'--prefix=/ ' .
|
||||||
'--libdir=lib ' .
|
'--libdir=lib ' .
|
||||||
@ -74,7 +74,7 @@ class openssl extends LinuxLibraryBase
|
|||||||
"linux-{$this->builder->getOption('arch')}{$clang_postfix}"
|
"linux-{$this->builder->getOption('arch')}{$clang_postfix}"
|
||||||
)
|
)
|
||||||
->exec('make clean')
|
->exec('make clean')
|
||||||
->exec("make -j{$this->builder->concurrency} CNF_EX_LIBS=\"{$ex_lib}\"")
|
->execWithEnv("make -j{$this->builder->concurrency} CNF_EX_LIBS=\"{$ex_lib}\"")
|
||||||
->exec("make install_sw DESTDIR={$destdir}");
|
->exec("make install_sw DESTDIR={$destdir}");
|
||||||
$this->patchPkgconfPrefix(['libssl.pc', 'openssl.pc', 'libcrypto.pc']);
|
$this->patchPkgconfPrefix(['libssl.pc', 'openssl.pc', 'libcrypto.pc']);
|
||||||
// patch for openssl 3.3.0+
|
// patch for openssl 3.3.0+
|
||||||
|
|||||||
@ -11,6 +11,7 @@ use SPC\exception\RuntimeException;
|
|||||||
use SPC\exception\WrongUsageException;
|
use SPC\exception\WrongUsageException;
|
||||||
use SPC\store\FileSystem;
|
use SPC\store\FileSystem;
|
||||||
use SPC\store\SourcePatcher;
|
use SPC\store\SourcePatcher;
|
||||||
|
use SPC\util\GlobalEnvManager;
|
||||||
|
|
||||||
class MacOSBuilder extends UnixBuilderBase
|
class MacOSBuilder extends UnixBuilderBase
|
||||||
{
|
{
|
||||||
@ -26,28 +27,15 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
{
|
{
|
||||||
$this->options = $options;
|
$this->options = $options;
|
||||||
|
|
||||||
// ---------- set necessary options ----------
|
// apply global environment variables
|
||||||
// set C Compiler (default: clang)
|
GlobalEnvManager::init($this);
|
||||||
f_putenv('CC=' . $this->getOption('cc', 'clang'));
|
|
||||||
// set C++ Composer (default: clang++)
|
|
||||||
f_putenv('CXX=' . $this->getOption('cxx', 'clang++'));
|
|
||||||
// set PATH
|
|
||||||
f_putenv('PATH=' . BUILD_ROOT_PATH . '/bin:' . getenv('PATH'));
|
|
||||||
// set PKG_CONFIG
|
|
||||||
f_putenv('PKG_CONFIG=' . BUILD_ROOT_PATH . '/bin/pkg-config');
|
|
||||||
// set PKG_CONFIG_PATH
|
|
||||||
f_putenv('PKG_CONFIG_PATH=' . BUILD_LIB_PATH . '/pkgconfig/');
|
|
||||||
|
|
||||||
// set arch (default: current)
|
// ---------- set necessary compile vars ----------
|
||||||
$this->setOptionIfNotExist('arch', php_uname('m'));
|
|
||||||
$this->setOptionIfNotExist('gnu-arch', arch2gnu($this->getOption('arch')));
|
|
||||||
|
|
||||||
// ---------- set necessary compile environments ----------
|
|
||||||
// concurrency
|
// concurrency
|
||||||
$this->concurrency = SystemUtil::getCpuCount();
|
$this->concurrency = intval(getenv('SPC_CONCURRENCY'));
|
||||||
// cflags
|
// cflags
|
||||||
$this->arch_c_flags = SystemUtil::getArchCFlags($this->getOption('arch'));
|
$this->arch_c_flags = getenv('SPC_DEFAULT_C_FLAGS');
|
||||||
$this->arch_cxx_flags = SystemUtil::getArchCFlags($this->getOption('arch'));
|
$this->arch_cxx_flags = getenv('SPC_DEFAULT_CXX_FLAGS');
|
||||||
// cmake toolchain
|
// cmake toolchain
|
||||||
$this->cmake_toolchain_file = SystemUtil::makeCmakeToolchainFile('Darwin', $this->getOption('arch'), $this->arch_c_flags);
|
$this->cmake_toolchain_file = SystemUtil::makeCmakeToolchainFile('Darwin', $this->getOption('arch'), $this->arch_c_flags);
|
||||||
|
|
||||||
@ -123,24 +111,25 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
*/
|
*/
|
||||||
public function buildPHP(int $build_target = BUILD_TARGET_NONE): void
|
public function buildPHP(int $build_target = BUILD_TARGET_NONE): void
|
||||||
{
|
{
|
||||||
|
$extra_libs = getenv('SPC_EXTRA_LIBS') ?: '';
|
||||||
// ---------- Update extra-libs ----------
|
// ---------- Update extra-libs ----------
|
||||||
$extra_libs = $this->getOption('extra-libs', '');
|
|
||||||
// add macOS frameworks
|
// add macOS frameworks
|
||||||
$extra_libs .= (empty($extra_libs) ? '' : ' ') . $this->getFrameworks(true);
|
$extra_libs .= (empty($extra_libs) ? '' : ' ') . $this->getFrameworks(true);
|
||||||
// add libc++, some extensions or libraries need it (C++ cannot be linked statically)
|
// add libc++, some extensions or libraries need it (C++ cannot be linked statically)
|
||||||
$extra_libs .= (empty($extra_libs) ? '' : ' ') . ($this->hasCpp() ? '-lc++ ' : '');
|
$extra_libs .= (empty($extra_libs) ? '' : ' ') . ($this->hasCpp() ? '-lc++ ' : '');
|
||||||
|
// bloat means force-load all static libraries, even if they are not used
|
||||||
if (!$this->getOption('bloat', false)) {
|
if (!$this->getOption('bloat', false)) {
|
||||||
$extra_libs .= (empty($extra_libs) ? '' : ' ') . implode(' ', $this->getAllStaticLibFiles());
|
$extra_libs .= (empty($extra_libs) ? '' : ' ') . implode(' ', $this->getAllStaticLibFiles());
|
||||||
} else {
|
} else {
|
||||||
logger()->info('bloat linking');
|
logger()->info('bloat linking');
|
||||||
$extra_libs .= (empty($extra_libs) ? '' : ' ') . implode(' ', array_map(fn ($x) => "-Wl,-force_load,{$x}", array_filter($this->getAllStaticLibFiles())));
|
$extra_libs .= (empty($extra_libs) ? '' : ' ') . implode(' ', array_map(fn ($x) => "-Wl,-force_load,{$x}", array_filter($this->getAllStaticLibFiles())));
|
||||||
}
|
}
|
||||||
$this->setOption('extra-libs', $extra_libs);
|
f_putenv('SPC_EXTRA_LIBS=' . $extra_libs);
|
||||||
|
|
||||||
$this->emitPatchPoint('before-php-buildconf');
|
$this->emitPatchPoint('before-php-buildconf');
|
||||||
SourcePatcher::patchBeforeBuildconf($this);
|
SourcePatcher::patchBeforeBuildconf($this);
|
||||||
|
|
||||||
shell()->cd(SOURCE_PATH . '/php-src')->exec('./buildconf --force');
|
shell()->cd(SOURCE_PATH . '/php-src')->exec(getenv('SPC_CMD_PREFIX_PHP_BUILDCONF'));
|
||||||
|
|
||||||
$this->emitPatchPoint('before-php-configure');
|
$this->emitPatchPoint('before-php-configure');
|
||||||
SourcePatcher::patchBeforeConfigure($this);
|
SourcePatcher::patchBeforeConfigure($this);
|
||||||
@ -155,9 +144,9 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
|
|
||||||
// prepare build php envs
|
// prepare build php envs
|
||||||
$envs_build_php = SystemUtil::makeEnvVarString([
|
$envs_build_php = SystemUtil::makeEnvVarString([
|
||||||
'CFLAGS' => " {$this->arch_c_flags} -Werror=unknown-warning-option ",
|
'CFLAGS' => getenv('SPC_CMD_VAR_PHP_CONFIGURE_CFLAGS'),
|
||||||
'CPPFLAGS' => '-I' . BUILD_INCLUDE_PATH,
|
'CPPFLAGS' => getenv('SPC_CMD_VAR_PHP_CONFIGURE_CPPFLAGS'),
|
||||||
'LDFLAGS' => '-L' . BUILD_LIB_PATH,
|
'LDFLAGS' => getenv('SPC_CMD_VAR_PHP_CONFIGURE_LDFLAGS'),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
if ($this->getLib('postgresql')) {
|
if ($this->getLib('postgresql')) {
|
||||||
@ -170,14 +159,7 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
|
|
||||||
shell()->cd(SOURCE_PATH . '/php-src')
|
shell()->cd(SOURCE_PATH . '/php-src')
|
||||||
->exec(
|
->exec(
|
||||||
'./configure ' .
|
getenv('SPC_CMD_PREFIX_PHP_CONFIGURE') . ' ' .
|
||||||
'--prefix= ' .
|
|
||||||
'--with-valgrind=no ' . // Not detect memory leak
|
|
||||||
'--enable-shared=no ' .
|
|
||||||
'--enable-static=yes ' .
|
|
||||||
'--disable-all ' .
|
|
||||||
'--disable-cgi ' .
|
|
||||||
'--disable-phpdbg ' .
|
|
||||||
($enableCli ? '--enable-cli ' : '--disable-cli ') .
|
($enableCli ? '--enable-cli ' : '--disable-cli ') .
|
||||||
($enableFpm ? '--enable-fpm ' : '--disable-fpm ') .
|
($enableFpm ? '--enable-fpm ' : '--disable-fpm ') .
|
||||||
($enableEmbed ? '--enable-embed=static ' : '--disable-embed ') .
|
($enableEmbed ? '--enable-embed=static ' : '--disable-embed ') .
|
||||||
@ -227,10 +209,10 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
*/
|
*/
|
||||||
protected function buildCli(): void
|
protected function buildCli(): void
|
||||||
{
|
{
|
||||||
$vars = SystemUtil::makeEnvVarString($this->getBuildVars());
|
$vars = SystemUtil::makeEnvVarString($this->getMakeExtraVars());
|
||||||
|
|
||||||
$shell = shell()->cd(SOURCE_PATH . '/php-src');
|
$shell = shell()->cd(SOURCE_PATH . '/php-src');
|
||||||
$shell->exec("make -j{$this->concurrency} {$vars} cli");
|
$shell->exec("\$SPC_CMD_PREFIX_PHP_MAKE {$vars} cli");
|
||||||
if (!$this->getOption('no-strip', false)) {
|
if (!$this->getOption('no-strip', false)) {
|
||||||
$shell->exec('dsymutil -f sapi/cli/php')->exec('strip sapi/cli/php');
|
$shell->exec('dsymutil -f sapi/cli/php')->exec('strip sapi/cli/php');
|
||||||
}
|
}
|
||||||
@ -255,18 +237,17 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
}
|
}
|
||||||
|
|
||||||
$enable_fake_cli = $this->getOption('with-micro-fake-cli', false) ? ' -DPHP_MICRO_FAKE_CLI' : '';
|
$enable_fake_cli = $this->getOption('with-micro-fake-cli', false) ? ' -DPHP_MICRO_FAKE_CLI' : '';
|
||||||
$vars = [
|
$vars = $this->getMakeExtraVars();
|
||||||
// with debug information, optimize for size, remove identifiers, patch fake cli for micro
|
|
||||||
'EXTRA_CFLAGS' => '-g -Os -fno-ident' . $enable_fake_cli,
|
// patch fake cli for micro
|
||||||
];
|
$vars['EXTRA_CFLAGS'] .= $enable_fake_cli;
|
||||||
$vars = $this->getBuildVars($vars);
|
|
||||||
if (!$this->getOption('no-strip', false)) {
|
if (!$this->getOption('no-strip', false)) {
|
||||||
$vars['STRIP'] = 'dsymutil -f ';
|
$vars['STRIP'] = 'dsymutil -f ';
|
||||||
}
|
}
|
||||||
$vars = SystemUtil::makeEnvVarString($vars);
|
$vars = SystemUtil::makeEnvVarString($vars);
|
||||||
|
|
||||||
shell()->cd(SOURCE_PATH . '/php-src')
|
shell()->cd(SOURCE_PATH . '/php-src')->exec(getenv('SPC_CMD_PREFIX_PHP_MAKE') . " {$vars} micro");
|
||||||
->exec("make -j{$this->concurrency} {$vars} micro");
|
|
||||||
$this->deployBinary(BUILD_TARGET_MICRO);
|
$this->deployBinary(BUILD_TARGET_MICRO);
|
||||||
|
|
||||||
if ($this->phar_patched) {
|
if ($this->phar_patched) {
|
||||||
@ -282,10 +263,10 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
*/
|
*/
|
||||||
protected function buildFpm(): void
|
protected function buildFpm(): void
|
||||||
{
|
{
|
||||||
$vars = SystemUtil::makeEnvVarString($this->getBuildVars());
|
$vars = SystemUtil::makeEnvVarString($this->getMakeExtraVars());
|
||||||
|
|
||||||
$shell = shell()->cd(SOURCE_PATH . '/php-src');
|
$shell = shell()->cd(SOURCE_PATH . '/php-src');
|
||||||
$shell->exec("make -j{$this->concurrency} {$vars} fpm");
|
$shell->exec(getenv('SPC_CMD_PREFIX_PHP_MAKE') . " {$vars} fpm");
|
||||||
if (!$this->getOption('no-strip', false)) {
|
if (!$this->getOption('no-strip', false)) {
|
||||||
$shell->exec('dsymutil -f sapi/fpm/php-fpm')->exec('strip sapi/fpm/php-fpm');
|
$shell->exec('dsymutil -f sapi/fpm/php-fpm')->exec('strip sapi/fpm/php-fpm');
|
||||||
}
|
}
|
||||||
@ -299,11 +280,10 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
*/
|
*/
|
||||||
protected function buildEmbed(): void
|
protected function buildEmbed(): void
|
||||||
{
|
{
|
||||||
$vars = SystemUtil::makeEnvVarString($this->getBuildVars());
|
$vars = SystemUtil::makeEnvVarString($this->getMakeExtraVars());
|
||||||
|
|
||||||
shell()
|
shell()->cd(SOURCE_PATH . '/php-src')
|
||||||
->cd(SOURCE_PATH . '/php-src')
|
->exec(getenv('SPC_CMD_PREFIX_PHP_MAKE') . ' INSTALL_ROOT=' . BUILD_ROOT_PATH . " {$vars} install")
|
||||||
->exec('make INSTALL_ROOT=' . BUILD_ROOT_PATH . " -j{$this->concurrency} {$vars} install")
|
|
||||||
// Workaround for https://github.com/php/php-src/issues/12082
|
// Workaround for https://github.com/php/php-src/issues/12082
|
||||||
->exec('rm -Rf ' . BUILD_ROOT_PATH . '/lib/php-o')
|
->exec('rm -Rf ' . BUILD_ROOT_PATH . '/lib/php-o')
|
||||||
->exec('mkdir ' . BUILD_ROOT_PATH . '/lib/php-o')
|
->exec('mkdir ' . BUILD_ROOT_PATH . '/lib/php-o')
|
||||||
@ -314,14 +294,11 @@ class MacOSBuilder extends UnixBuilderBase
|
|||||||
->exec('rm -Rf ' . BUILD_ROOT_PATH . '/lib/php-o');
|
->exec('rm -Rf ' . BUILD_ROOT_PATH . '/lib/php-o');
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getBuildVars($input = []): array
|
private function getMakeExtraVars(): array
|
||||||
{
|
{
|
||||||
$optimization = $this->getOption('no-strip', false) ? '-g -O0' : '-g0 -Os';
|
|
||||||
$cflags = isset($input['EXTRA_CFLAGS']) && $input['EXTRA_CFLAGS'] ? " {$input['EXTRA_CFLAGS']}" : '';
|
|
||||||
$libs = isset($input['EXTRA_LIBS']) && $input['EXTRA_LIBS'] ? " {$input['EXTRA_LIBS']}" : '';
|
|
||||||
return [
|
return [
|
||||||
'EXTRA_CFLAGS' => "{$optimization} {$cflags} " . $this->getOption('x-extra-cflags'),
|
'EXTRA_CFLAGS' => getenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_CFLAGS'),
|
||||||
'EXTRA_LIBS' => "{$this->getOption('extra-libs')} -lresolv {$libs} " . $this->getOption('x-extra-libs'),
|
'EXTRA_LIBS' => getenv('SPC_EXTRA_LIBS') . ' ' . getenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_LIBS'),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -48,6 +48,7 @@ class openssl extends MacOSLibraryBase
|
|||||||
}
|
}
|
||||||
|
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
->exec(
|
->exec(
|
||||||
"./Configure no-shared {$extra} " .
|
"./Configure no-shared {$extra} " .
|
||||||
'--prefix=/ ' . // use prefix=/
|
'--prefix=/ ' . // use prefix=/
|
||||||
@ -56,7 +57,7 @@ class openssl extends MacOSLibraryBase
|
|||||||
"darwin64-{$this->builder->getOption('arch')}-cc"
|
"darwin64-{$this->builder->getOption('arch')}-cc"
|
||||||
)
|
)
|
||||||
->exec('make clean')
|
->exec('make clean')
|
||||||
->exec("make -j{$this->builder->concurrency} CNF_EX_LIBS=\"{$ex_lib}\"")
|
->execWithEnv("make -j{$this->builder->concurrency} CNF_EX_LIBS=\"{$ex_lib}\"")
|
||||||
->exec("make install_sw DESTDIR={$destdir}");
|
->exec("make install_sw DESTDIR={$destdir}");
|
||||||
$this->patchPkgconfPrefix(['libssl.pc', 'openssl.pc', 'libcrypto.pc']);
|
$this->patchPkgconfPrefix(['libssl.pc', 'openssl.pc', 'libcrypto.pc']);
|
||||||
// patch for openssl 3.3.0+
|
// patch for openssl 3.3.0+
|
||||||
|
|||||||
@ -99,4 +99,19 @@ trait UnixLibraryTrait
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getLibExtraCFlags(): string
|
||||||
|
{
|
||||||
|
return getenv($this->getSnakeCaseName() . '_CFLAGS') ?: '';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getLibExtraLdFlags(): string
|
||||||
|
{
|
||||||
|
return getenv($this->getSnakeCaseName() . '_LDFLAGS') ?: '';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getLibExtraLibs(): string
|
||||||
|
{
|
||||||
|
return getenv($this->getSnakeCaseName() . '_LIBS') ?: '';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -18,14 +18,15 @@ trait brotli
|
|||||||
{
|
{
|
||||||
FileSystem::resetDir($this->source_dir . '/build-dir');
|
FileSystem::resetDir($this->source_dir . '/build-dir');
|
||||||
shell()->cd($this->source_dir . '/build-dir')
|
shell()->cd($this->source_dir . '/build-dir')
|
||||||
->exec(
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
|
->execWithEnv(
|
||||||
'cmake ' .
|
'cmake ' .
|
||||||
"{$this->builder->makeCmakeArgs()} " .
|
"{$this->builder->makeCmakeArgs()} " .
|
||||||
'-DBUILD_SHARED_LIBS=OFF ' .
|
'-DBUILD_SHARED_LIBS=OFF ' .
|
||||||
'..'
|
'..'
|
||||||
)
|
)
|
||||||
->exec("cmake --build . -j {$this->builder->concurrency}")
|
->execWithEnv("cmake --build . -j {$this->builder->concurrency}")
|
||||||
->exec('make install DESTDIR=' . BUILD_ROOT_PATH);
|
->execWithEnv('make install DESTDIR=' . BUILD_ROOT_PATH);
|
||||||
$this->patchPkgconfPrefix(['libbrotlicommon.pc', 'libbrotlidec.pc', 'libbrotlienc.pc']);
|
$this->patchPkgconfPrefix(['libbrotlicommon.pc', 'libbrotlidec.pc', 'libbrotlienc.pc']);
|
||||||
shell()->cd(BUILD_ROOT_PATH . '/lib')->exec('ln -sf libbrotlicommon.a libbrotli.a');
|
shell()->cd(BUILD_ROOT_PATH . '/lib')->exec('ln -sf libbrotlicommon.a libbrotli.a');
|
||||||
foreach (FileSystem::scanDirFiles(BUILD_ROOT_PATH . '/lib/', false, true) as $filename) {
|
foreach (FileSystem::scanDirFiles(BUILD_ROOT_PATH . '/lib/', false, true) as $filename) {
|
||||||
|
|||||||
@ -9,8 +9,9 @@ trait bzip2
|
|||||||
protected function build(): void
|
protected function build(): void
|
||||||
{
|
{
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
->exec("make PREFIX='" . BUILD_ROOT_PATH . "' clean")
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
->exec("make -j{$this->builder->concurrency} {$this->builder->getEnvString()} PREFIX='" . BUILD_ROOT_PATH . "' libbz2.a")
|
->execWithEnv("make PREFIX='" . BUILD_ROOT_PATH . "' clean")
|
||||||
|
->execWithEnv("make -j{$this->builder->concurrency} {$this->builder->getEnvString()} PREFIX='" . BUILD_ROOT_PATH . "' libbz2.a")
|
||||||
->exec('cp libbz2.a ' . BUILD_LIB_PATH)
|
->exec('cp libbz2.a ' . BUILD_LIB_PATH)
|
||||||
->exec('cp bzlib.h ' . BUILD_INCLUDE_PATH);
|
->exec('cp bzlib.h ' . BUILD_INCLUDE_PATH);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -51,10 +51,11 @@ trait curl
|
|||||||
FileSystem::resetDir($this->source_dir . '/build');
|
FileSystem::resetDir($this->source_dir . '/build');
|
||||||
// compile!
|
// compile!
|
||||||
shell()->cd($this->source_dir . '/build')
|
shell()->cd($this->source_dir . '/build')
|
||||||
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
->exec('sed -i.save s@\${CMAKE_C_IMPLICIT_LINK_LIBRARIES}@@ ../CMakeLists.txt')
|
->exec('sed -i.save s@\${CMAKE_C_IMPLICIT_LINK_LIBRARIES}@@ ../CMakeLists.txt')
|
||||||
->exec("cmake {$this->builder->makeCmakeArgs()} -DBUILD_SHARED_LIBS=OFF -DBUILD_CURL_EXE=OFF -DBUILD_LIBCURL_DOCS=OFF {$extra} ..")
|
->execWithEnv("cmake {$this->builder->makeCmakeArgs()} -DBUILD_SHARED_LIBS=OFF -DBUILD_CURL_EXE=OFF -DBUILD_LIBCURL_DOCS=OFF {$extra} ..")
|
||||||
->exec("make -j{$this->builder->concurrency}")
|
->execWithEnv("make -j{$this->builder->concurrency}")
|
||||||
->exec('make install DESTDIR=' . BUILD_ROOT_PATH);
|
->execWithEnv('make install DESTDIR=' . BUILD_ROOT_PATH);
|
||||||
// patch pkgconf
|
// patch pkgconf
|
||||||
$this->patchPkgconfPrefix(['libcurl.pc']);
|
$this->patchPkgconfPrefix(['libcurl.pc']);
|
||||||
shell()->cd(BUILD_LIB_PATH . '/cmake/CURL/')
|
shell()->cd(BUILD_LIB_PATH . '/cmake/CURL/')
|
||||||
|
|||||||
@ -26,15 +26,16 @@ trait freetype
|
|||||||
$suggested .= ' ';
|
$suggested .= ' ';
|
||||||
|
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
->exec('sh autogen.sh')
|
->exec('sh autogen.sh')
|
||||||
->exec(
|
->execWithEnv(
|
||||||
'./configure ' .
|
'./configure ' .
|
||||||
'--enable-static --disable-shared --without-harfbuzz --prefix= ' .
|
'--enable-static --disable-shared --without-harfbuzz --prefix= ' .
|
||||||
$suggested
|
$suggested
|
||||||
)
|
)
|
||||||
->exec('make clean')
|
->execWithEnv('make clean')
|
||||||
->exec("make -j{$this->builder->concurrency}")
|
->execWithEnv("make -j{$this->builder->concurrency}")
|
||||||
->exec('make install DESTDIR=' . BUILD_ROOT_PATH);
|
->execWithEnv('make install DESTDIR=' . BUILD_ROOT_PATH);
|
||||||
$this->patchPkgconfPrefix(['freetype2.pc']);
|
$this->patchPkgconfPrefix(['freetype2.pc']);
|
||||||
FileSystem::replaceFileStr(
|
FileSystem::replaceFileStr(
|
||||||
BUILD_ROOT_PATH . '/lib/pkgconfig/freetype2.pc',
|
BUILD_ROOT_PATH . '/lib/pkgconfig/freetype2.pc',
|
||||||
|
|||||||
@ -11,7 +11,8 @@ trait gettext
|
|||||||
$extra = $this->builder->getLib('ncurses') ? ('--with-libncurses-prefix=' . BUILD_ROOT_PATH . ' ') : '';
|
$extra = $this->builder->getLib('ncurses') ? ('--with-libncurses-prefix=' . BUILD_ROOT_PATH . ' ') : '';
|
||||||
$extra .= $this->builder->getLib('libxml2') ? ('--with-libxml2-prefix=' . BUILD_ROOT_PATH . ' ') : '';
|
$extra .= $this->builder->getLib('libxml2') ? ('--with-libxml2-prefix=' . BUILD_ROOT_PATH . ' ') : '';
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
->exec(
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
|
->execWithEnv(
|
||||||
'./configure ' .
|
'./configure ' .
|
||||||
'--enable-static ' .
|
'--enable-static ' .
|
||||||
'--disable-shared ' .
|
'--disable-shared ' .
|
||||||
@ -21,8 +22,8 @@ trait gettext
|
|||||||
'--with-libiconv-prefix=' . BUILD_ROOT_PATH . ' ' .
|
'--with-libiconv-prefix=' . BUILD_ROOT_PATH . ' ' .
|
||||||
'--prefix=' . BUILD_ROOT_PATH
|
'--prefix=' . BUILD_ROOT_PATH
|
||||||
)
|
)
|
||||||
->exec('make clean')
|
->execWithEnv('make clean')
|
||||||
->exec("make -j{$this->builder->concurrency}")
|
->execWithEnv("make -j{$this->builder->concurrency}")
|
||||||
->exec('make install');
|
->execWithEnv('make install');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -16,13 +16,14 @@ trait gmp
|
|||||||
protected function build(): void
|
protected function build(): void
|
||||||
{
|
{
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
->exec(
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
|
->execWithEnv(
|
||||||
'./configure ' .
|
'./configure ' .
|
||||||
'--enable-static --disable-shared ' .
|
'--enable-static --disable-shared ' .
|
||||||
'--prefix='
|
'--prefix='
|
||||||
)
|
)
|
||||||
->exec('make clean')
|
->execWithEnv('make clean')
|
||||||
->exec("make -j{$this->builder->concurrency}")
|
->execWithEnv("make -j{$this->builder->concurrency}")
|
||||||
->exec('make install DESTDIR=' . BUILD_ROOT_PATH);
|
->exec('make install DESTDIR=' . BUILD_ROOT_PATH);
|
||||||
$this->patchPkgconfPrefix(['gmp.pc']);
|
$this->patchPkgconfPrefix(['gmp.pc']);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -39,15 +39,18 @@ trait imagemagick
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$ldflags = $this instanceof LinuxLibraryBase ? ('LDFLAGS="-static" ') : '';
|
$ldflags = $this instanceof LinuxLibraryBase ? ('-static') : '';
|
||||||
|
|
||||||
// libxml iconv patch
|
// libxml iconv patch
|
||||||
$required_libs .= $this instanceof MacOSLibraryBase ? (' -liconv') : '';
|
$required_libs .= $this instanceof MacOSLibraryBase ? ('-liconv') : '';
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
->exec(
|
->setEnv([
|
||||||
'PKG_CONFIG="$PKG_CONFIG --static" ' .
|
'CFLAGS' => $this->getLibExtraCFlags(),
|
||||||
$ldflags .
|
'LDFLAGS' => $this->getLibExtraLdFlags() ?: $ldflags,
|
||||||
"LIBS='{$required_libs}' " .
|
'LIBS' => $this->getLibExtraLibs() ?: $required_libs,
|
||||||
|
'PKG_CONFIG' => '$PKG_CONFIG --static',
|
||||||
|
])
|
||||||
|
->execWithEnv(
|
||||||
'./configure ' .
|
'./configure ' .
|
||||||
'--enable-static --disable-shared ' .
|
'--enable-static --disable-shared ' .
|
||||||
$extra .
|
$extra .
|
||||||
|
|||||||
@ -25,9 +25,15 @@ trait ldap
|
|||||||
$alt .= $this->builder->getLib('libsodium') ? '--with-argon2=libsodium ' : '--enable-argon2=no ';
|
$alt .= $this->builder->getLib('libsodium') ? '--with-argon2=libsodium ' : '--enable-argon2=no ';
|
||||||
f_putenv('PKG_CONFIG=' . BUILD_ROOT_PATH . '/bin/pkg-config');
|
f_putenv('PKG_CONFIG=' . BUILD_ROOT_PATH . '/bin/pkg-config');
|
||||||
f_putenv('PKG_CONFIG_PATH=' . BUILD_LIB_PATH . '/pkgconfig');
|
f_putenv('PKG_CONFIG_PATH=' . BUILD_LIB_PATH . '/pkgconfig');
|
||||||
|
$ldflags = '-L' . BUILD_LIB_PATH;
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
->exec(
|
->setEnv([
|
||||||
$this->builder->makeAutoconfFlags(AUTOCONF_LDFLAGS | AUTOCONF_CPPFLAGS) .
|
'CFLAGS' => $this->getLibExtraCFlags(),
|
||||||
|
'LDFLAGS' => $this->getLibExtraLdFlags() ?: $ldflags,
|
||||||
|
'LIBS' => $this->getLibExtraLibs(),
|
||||||
|
])
|
||||||
|
->execWithEnv(
|
||||||
|
$this->builder->makeAutoconfFlags(AUTOCONF_CPPFLAGS) .
|
||||||
' ./configure ' .
|
' ./configure ' .
|
||||||
'--enable-static ' .
|
'--enable-static ' .
|
||||||
'--disable-shared ' .
|
'--disable-shared ' .
|
||||||
|
|||||||
@ -11,9 +11,10 @@ trait libargon2
|
|||||||
protected function build()
|
protected function build()
|
||||||
{
|
{
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
->exec("make PREFIX='' clean")
|
->exec("make PREFIX='' clean")
|
||||||
->exec("make -j{$this->builder->concurrency} PREFIX=''")
|
->execWithEnv("make -j{$this->builder->concurrency} PREFIX=''")
|
||||||
->exec("make install PREFIX='' DESTDIR=" . BUILD_ROOT_PATH);
|
->execWithEnv("make install PREFIX='' DESTDIR=" . BUILD_ROOT_PATH);
|
||||||
|
|
||||||
$this->patchPkgconfPrefix(['libargon2.pc']);
|
$this->patchPkgconfPrefix(['libargon2.pc']);
|
||||||
|
|
||||||
|
|||||||
@ -22,9 +22,10 @@ trait libavif
|
|||||||
FileSystem::resetDir($this->source_dir . '/build');
|
FileSystem::resetDir($this->source_dir . '/build');
|
||||||
// Start build
|
// Start build
|
||||||
shell()->cd($this->source_dir . '/build')
|
shell()->cd($this->source_dir . '/build')
|
||||||
->exec("cmake {$this->builder->makeCmakeArgs()} -DBUILD_SHARED_LIBS=OFF ..")
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
->exec("cmake --build . -j {$this->builder->concurrency}")
|
->execWithEnv("cmake {$this->builder->makeCmakeArgs()} -DBUILD_SHARED_LIBS=OFF ..")
|
||||||
->exec('make install DESTDIR=' . BUILD_ROOT_PATH);
|
->execWithEnv("cmake --build . -j {$this->builder->concurrency}")
|
||||||
|
->execWithEnv('make install DESTDIR=' . BUILD_ROOT_PATH);
|
||||||
// patch pkgconfig
|
// patch pkgconfig
|
||||||
$this->patchPkgconfPrefix(['libavif.pc']);
|
$this->patchPkgconfPrefix(['libavif.pc']);
|
||||||
$this->cleanLaFiles();
|
$this->cleanLaFiles();
|
||||||
|
|||||||
@ -14,8 +14,9 @@ trait libcares
|
|||||||
protected function build(): void
|
protected function build(): void
|
||||||
{
|
{
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
->exec('./configure --prefix=' . BUILD_ROOT_PATH . ' --enable-static --disable-shared --disable-tests')
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
->exec("make -j {$this->builder->concurrency}")
|
->execWithEnv('./configure --prefix=' . BUILD_ROOT_PATH . ' --enable-static --disable-shared --disable-tests')
|
||||||
|
->execWithEnv("make -j {$this->builder->concurrency}")
|
||||||
->exec('make install');
|
->exec('make install');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -20,7 +20,8 @@ trait libevent
|
|||||||
FileSystem::resetDir($this->source_dir . '/build');
|
FileSystem::resetDir($this->source_dir . '/build');
|
||||||
// Start build
|
// Start build
|
||||||
shell()->cd($this->source_dir . '/build')
|
shell()->cd($this->source_dir . '/build')
|
||||||
->exec(
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags(), 'LDFLAGS' => $this->getLibExtraLdFlags(), 'LIBS' => $this->getLibExtraLibs()])
|
||||||
|
->execWithEnv(
|
||||||
'cmake ' .
|
'cmake ' .
|
||||||
'-DCMAKE_INSTALL_PREFIX=' . BUILD_ROOT_PATH . ' ' .
|
'-DCMAKE_INSTALL_PREFIX=' . BUILD_ROOT_PATH . ' ' .
|
||||||
"-DCMAKE_TOOLCHAIN_FILE={$this->builder->cmake_toolchain_file} " .
|
"-DCMAKE_TOOLCHAIN_FILE={$this->builder->cmake_toolchain_file} " .
|
||||||
@ -33,7 +34,7 @@ trait libevent
|
|||||||
'-DEVENT__DISABLE_SAMPLES=ON ' .
|
'-DEVENT__DISABLE_SAMPLES=ON ' .
|
||||||
'..'
|
'..'
|
||||||
)
|
)
|
||||||
->exec("cmake --build . -j {$this->builder->concurrency}")
|
->execWithEnv("cmake --build . -j {$this->builder->concurrency}")
|
||||||
->exec('make install');
|
->exec('make install');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -8,15 +8,12 @@ trait pkgconfig
|
|||||||
{
|
{
|
||||||
protected function build(): void
|
protected function build(): void
|
||||||
{
|
{
|
||||||
$macos_env = "CFLAGS='{$this->builder->arch_c_flags} -Wimplicit-function-declaration -Wno-int-conversion' ";
|
$cflags = PHP_OS_FAMILY === 'Darwin' ? "{$this->builder->arch_c_flags} -Wimplicit-function-declaration -Wno-int-conversion" : '';
|
||||||
$linux_env = 'LDFLAGS=--static ';
|
$ldflags = PHP_OS_FAMILY === 'Darwin' ? '' : '--static';
|
||||||
|
|
||||||
shell()->cd($this->source_dir)
|
shell()->cd($this->source_dir)
|
||||||
->exec(
|
->setEnv(['CFLAGS' => $this->getLibExtraCFlags() ?: $cflags, 'LDFLAGS' => $this->getLibExtraLdFlags() ?: $ldflags, 'LIBS' => $this->getLibExtraLibs()])
|
||||||
match (PHP_OS_FAMILY) {
|
->execWithEnv(
|
||||||
'Darwin' => $macos_env,
|
|
||||||
default => $linux_env,
|
|
||||||
} .
|
|
||||||
'./configure ' .
|
'./configure ' .
|
||||||
'--disable-shared ' .
|
'--disable-shared ' .
|
||||||
'--enable-static ' .
|
'--enable-static ' .
|
||||||
@ -30,8 +27,8 @@ trait pkgconfig
|
|||||||
'--without-pc-path'
|
'--without-pc-path'
|
||||||
)
|
)
|
||||||
->exec('make clean')
|
->exec('make clean')
|
||||||
->exec("make -j{$this->builder->concurrency}")
|
->execWithEnv("make -j{$this->builder->concurrency}")
|
||||||
->exec('make install-exec');
|
->execWithEnv('make install-exec');
|
||||||
shell()->exec('strip ' . BUILD_ROOT_PATH . '/bin/pkg-config');
|
shell()->exec('strip ' . BUILD_ROOT_PATH . '/bin/pkg-config');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -13,6 +13,7 @@ use SPC\store\FileSystem;
|
|||||||
use SPC\store\SourceManager;
|
use SPC\store\SourceManager;
|
||||||
use SPC\store\SourcePatcher;
|
use SPC\store\SourcePatcher;
|
||||||
use SPC\util\DependencyUtil;
|
use SPC\util\DependencyUtil;
|
||||||
|
use SPC\util\GlobalEnvManager;
|
||||||
|
|
||||||
class WindowsBuilder extends BuilderBase
|
class WindowsBuilder extends BuilderBase
|
||||||
{
|
{
|
||||||
@ -33,6 +34,8 @@ class WindowsBuilder extends BuilderBase
|
|||||||
{
|
{
|
||||||
$this->options = $options;
|
$this->options = $options;
|
||||||
|
|
||||||
|
GlobalEnvManager::init($this);
|
||||||
|
|
||||||
// ---------- set necessary options ----------
|
// ---------- set necessary options ----------
|
||||||
// set sdk (require visual studio 16 or 17)
|
// set sdk (require visual studio 16 or 17)
|
||||||
$vs = SystemUtil::findVisualStudio()['version'];
|
$vs = SystemUtil::findVisualStudio()['version'];
|
||||||
@ -42,7 +45,7 @@ class WindowsBuilder extends BuilderBase
|
|||||||
$this->zts = $this->getOption('enable-zts', false);
|
$this->zts = $this->getOption('enable-zts', false);
|
||||||
|
|
||||||
// set concurrency
|
// set concurrency
|
||||||
$this->concurrency = SystemUtil::getCpuCount();
|
$this->concurrency = intval(getenv('SPC_CONCURRENCY'));
|
||||||
|
|
||||||
// make cmake toolchain
|
// make cmake toolchain
|
||||||
$this->cmake_toolchain_file = SystemUtil::makeCmakeToolchainFile();
|
$this->cmake_toolchain_file = SystemUtil::makeCmakeToolchainFile();
|
||||||
@ -59,9 +62,10 @@ class WindowsBuilder extends BuilderBase
|
|||||||
public function buildPHP(int $build_target = BUILD_TARGET_NONE): void
|
public function buildPHP(int $build_target = BUILD_TARGET_NONE): void
|
||||||
{
|
{
|
||||||
// ---------- Update extra-libs ----------
|
// ---------- Update extra-libs ----------
|
||||||
$extra_libs = $this->getOption('extra-libs', '');
|
$extra_libs = getenv('SPC_EXTRA_LIBS') ?: '';
|
||||||
$extra_libs .= (empty($extra_libs) ? '' : ' ') . implode(' ', $this->getAllStaticLibFiles());
|
$extra_libs .= (empty($extra_libs) ? '' : ' ') . implode(' ', $this->getAllStaticLibFiles());
|
||||||
$this->setOption('extra-libs', $extra_libs);
|
f_putenv('SPC_EXTRA_LIBS=' . $extra_libs);
|
||||||
|
|
||||||
$enableCli = ($build_target & BUILD_TARGET_CLI) === BUILD_TARGET_CLI;
|
$enableCli = ($build_target & BUILD_TARGET_CLI) === BUILD_TARGET_CLI;
|
||||||
$enableFpm = ($build_target & BUILD_TARGET_FPM) === BUILD_TARGET_FPM;
|
$enableFpm = ($build_target & BUILD_TARGET_FPM) === BUILD_TARGET_FPM;
|
||||||
$enableMicro = ($build_target & BUILD_TARGET_MICRO) === BUILD_TARGET_MICRO;
|
$enableMicro = ($build_target & BUILD_TARGET_MICRO) === BUILD_TARGET_MICRO;
|
||||||
@ -80,7 +84,7 @@ class WindowsBuilder extends BuilderBase
|
|||||||
if ($this->getOption('with-upx-pack', false)) {
|
if ($this->getOption('with-upx-pack', false)) {
|
||||||
if (!file_exists($makefile . '.originfile')) {
|
if (!file_exists($makefile . '.originfile')) {
|
||||||
copy($makefile, $makefile . '.originfile');
|
copy($makefile, $makefile . '.originfile');
|
||||||
FileSystem::replaceFileStr($makefile, '$(MICRO_SFX):', "_MICRO_UPX = {$this->getOption('upx-exec')} --best $(MICRO_SFX)\n$(MICRO_SFX):");
|
FileSystem::replaceFileStr($makefile, '$(MICRO_SFX):', '_MICRO_UPX = ' . getenv('UPX_EXEC') . " --best $(MICRO_SFX)\n$(MICRO_SFX):");
|
||||||
FileSystem::replaceFileStr($makefile, '@$(_MICRO_MT)', "@$(_MICRO_MT)\n\t@$(_MICRO_UPX)");
|
FileSystem::replaceFileStr($makefile, '@$(_MICRO_MT)', "@$(_MICRO_MT)\n\t@$(_MICRO_UPX)");
|
||||||
}
|
}
|
||||||
} elseif (file_exists($makefile . '.originfile')) {
|
} elseif (file_exists($makefile . '.originfile')) {
|
||||||
@ -322,7 +326,7 @@ class WindowsBuilder extends BuilderBase
|
|||||||
|
|
||||||
// with-upx-pack for cli
|
// with-upx-pack for cli
|
||||||
if ($this->getOption('with-upx-pack', false) && $type === BUILD_TARGET_CLI) {
|
if ($this->getOption('with-upx-pack', false) && $type === BUILD_TARGET_CLI) {
|
||||||
cmd()->exec($this->getOption('upx-exec') . ' --best ' . escapeshellarg($src));
|
cmd()->exec(getenv('UPX_EXEC') . ' --best ' . escapeshellarg($src));
|
||||||
}
|
}
|
||||||
|
|
||||||
logger()->info('Deploying ' . $this->getBuildTypeName($type) . ' file');
|
logger()->info('Deploying ' . $this->getBuildTypeName($type) . ' file');
|
||||||
|
|||||||
@ -10,6 +10,7 @@ use SPC\exception\WrongUsageException;
|
|||||||
use SPC\store\FileSystem;
|
use SPC\store\FileSystem;
|
||||||
use SPC\store\SourcePatcher;
|
use SPC\store\SourcePatcher;
|
||||||
use SPC\util\DependencyUtil;
|
use SPC\util\DependencyUtil;
|
||||||
|
use SPC\util\GlobalEnvManager;
|
||||||
use SPC\util\LicenseDumper;
|
use SPC\util\LicenseDumper;
|
||||||
use Symfony\Component\Console\Attribute\AsCommand;
|
use Symfony\Component\Console\Attribute\AsCommand;
|
||||||
use Symfony\Component\Console\Input\InputArgument;
|
use Symfony\Component\Console\Input\InputArgument;
|
||||||
@ -117,7 +118,6 @@ class BuildCliCommand extends BuildCommand
|
|||||||
}
|
}
|
||||||
if ($this->input->getOption('with-upx-pack') && in_array(PHP_OS_FAMILY, ['Linux', 'Windows'])) {
|
if ($this->input->getOption('with-upx-pack') && in_array(PHP_OS_FAMILY, ['Linux', 'Windows'])) {
|
||||||
$indent_texts['UPX Pack'] = 'enabled';
|
$indent_texts['UPX Pack'] = 'enabled';
|
||||||
$builder->setOption('upx-exec', FileSystem::convertPath(PKG_ROOT_PATH . '/bin/upx' . $suffix));
|
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
$ver = $builder->getPHPVersion();
|
$ver = $builder->getPHPVersion();
|
||||||
@ -132,6 +132,7 @@ class BuildCliCommand extends BuildCommand
|
|||||||
$indent_texts['Extra Exts (' . count($not_included) . ')'] = implode(', ', $not_included);
|
$indent_texts['Extra Exts (' . count($not_included) . ')'] = implode(', ', $not_included);
|
||||||
}
|
}
|
||||||
$this->printFormatInfo($indent_texts);
|
$this->printFormatInfo($indent_texts);
|
||||||
|
$this->printFormatInfo($this->getDefinedEnvs(), true);
|
||||||
logger()->notice('Build will start after 2s ...');
|
logger()->notice('Build will start after 2s ...');
|
||||||
sleep(2);
|
sleep(2);
|
||||||
|
|
||||||
@ -226,7 +227,18 @@ class BuildCliCommand extends BuildCommand
|
|||||||
return $rule;
|
return $rule;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function printFormatInfo(array $indent_texts): void
|
private function getDefinedEnvs(): array
|
||||||
|
{
|
||||||
|
$envs = GlobalEnvManager::getInitializedEnv();
|
||||||
|
$final = [];
|
||||||
|
foreach ($envs as $env) {
|
||||||
|
$exp = explode('=', $env, 2);
|
||||||
|
$final['Init var [' . $exp[0] . ']'] = $exp[1];
|
||||||
|
}
|
||||||
|
return $final;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function printFormatInfo(array $indent_texts, bool $debug = false): void
|
||||||
{
|
{
|
||||||
// calculate space count for every line
|
// calculate space count for every line
|
||||||
$maxlen = 0;
|
$maxlen = 0;
|
||||||
@ -236,14 +248,14 @@ class BuildCliCommand extends BuildCommand
|
|||||||
foreach ($indent_texts as $k => $v) {
|
foreach ($indent_texts as $k => $v) {
|
||||||
if (is_string($v)) {
|
if (is_string($v)) {
|
||||||
/* @phpstan-ignore-next-line */
|
/* @phpstan-ignore-next-line */
|
||||||
logger()->info($k . ': ' . str_pad('', $maxlen - strlen($k)) . ConsoleColor::yellow($v));
|
logger()->{$debug ? 'debug' : 'info'}($k . ': ' . str_pad('', $maxlen - strlen($k)) . ConsoleColor::yellow($v));
|
||||||
} elseif (is_array($v) && !is_assoc_array($v)) {
|
} elseif (is_array($v) && !is_assoc_array($v)) {
|
||||||
$first = array_shift($v);
|
$first = array_shift($v);
|
||||||
/* @phpstan-ignore-next-line */
|
/* @phpstan-ignore-next-line */
|
||||||
logger()->info($k . ': ' . str_pad('', $maxlen - strlen($k)) . ConsoleColor::yellow($first));
|
logger()->{$debug ? 'debug' : 'info'}($k . ': ' . str_pad('', $maxlen - strlen($k)) . ConsoleColor::yellow($first));
|
||||||
foreach ($v as $vs) {
|
foreach ($v as $vs) {
|
||||||
/* @phpstan-ignore-next-line */
|
/* @phpstan-ignore-next-line */
|
||||||
logger()->info(str_pad('', $maxlen + 2) . ConsoleColor::yellow($vs));
|
logger()->{$debug ? 'debug' : 'info'}(str_pad('', $maxlen + 2) . ConsoleColor::yellow($vs));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
187
src/SPC/util/GlobalEnvManager.php
Normal file
187
src/SPC/util/GlobalEnvManager.php
Normal file
@ -0,0 +1,187 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace SPC\util;
|
||||||
|
|
||||||
|
use SPC\builder\BuilderBase;
|
||||||
|
use SPC\builder\freebsd\SystemUtil as BSDSystemUtil;
|
||||||
|
use SPC\builder\linux\SystemUtil as LinuxSystemUtil;
|
||||||
|
use SPC\builder\macos\SystemUtil as MacOSSystemUtil;
|
||||||
|
use SPC\builder\windows\SystemUtil as WindowsSystemUtil;
|
||||||
|
use SPC\exception\RuntimeException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Environment variable manager
|
||||||
|
*/
|
||||||
|
class GlobalEnvManager
|
||||||
|
{
|
||||||
|
private static array $env_cache = [];
|
||||||
|
|
||||||
|
public static function getInitializedEnv(): array
|
||||||
|
{
|
||||||
|
return self::$env_cache;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the environment variables
|
||||||
|
*
|
||||||
|
* @param BuilderBase $builder Builder
|
||||||
|
* @throws RuntimeException
|
||||||
|
*/
|
||||||
|
public static function init(BuilderBase $builder): void
|
||||||
|
{
|
||||||
|
// Init global env, build related path
|
||||||
|
self::putenv('BUILD_ROOT_PATH=' . BUILD_ROOT_PATH);
|
||||||
|
self::putenv('BUILD_INCLUDE_PATH=' . BUILD_INCLUDE_PATH);
|
||||||
|
self::putenv('BUILD_LIB_PATH=' . BUILD_LIB_PATH);
|
||||||
|
self::putenv('BUILD_BIN_PATH=' . BUILD_BIN_PATH);
|
||||||
|
self::putenv('PKG_ROOT_PATH=' . PKG_ROOT_PATH);
|
||||||
|
self::putenv('SOURCE_PATH=' . SOURCE_PATH);
|
||||||
|
self::putenv('DOWNLOAD_PATH=' . DOWNLOAD_PATH);
|
||||||
|
|
||||||
|
// Init system-specific env
|
||||||
|
match (PHP_OS_FAMILY) {
|
||||||
|
'Windows' => self::initWindowsEnv($builder),
|
||||||
|
'Darwin' => self::initDarwinEnv($builder),
|
||||||
|
'Linux' => self::initLinuxEnv($builder),
|
||||||
|
'BSD' => 'TODO',
|
||||||
|
default => logger()->warning('Unknown OS: ' . PHP_OS_FAMILY),
|
||||||
|
};
|
||||||
|
|
||||||
|
// Init SPC env
|
||||||
|
self::initIfNotExists('SPC_CONCURRENCY', match (PHP_OS_FAMILY) {
|
||||||
|
'Windows' => (string) WindowsSystemUtil::getCpuCount(),
|
||||||
|
'Darwin' => (string) MacOSSystemUtil::getCpuCount(),
|
||||||
|
'Linux' => (string) LinuxSystemUtil::getCpuCount(),
|
||||||
|
'BSD' => (string) BSDSystemUtil::getCpuCount(),
|
||||||
|
default => '1',
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function initWindowsEnv(BuilderBase $builder): void
|
||||||
|
{
|
||||||
|
// Windows need php-sdk binary tools
|
||||||
|
self::initIfNotExists('PHP_SDK_PATH', WORKING_DIR . DIRECTORY_SEPARATOR . 'php-sdk-binary-tools');
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function initLinuxEnv(BuilderBase $builder): void
|
||||||
|
{
|
||||||
|
// Init C Compiler and C++ Compiler (alpine)
|
||||||
|
if (\SPC\builder\linux\SystemUtil::isMuslDist()) {
|
||||||
|
self::initIfNotExists('CC', 'gcc');
|
||||||
|
self::initIfNotExists('CXX', 'g++');
|
||||||
|
self::initIfNotExists('AR', 'ar');
|
||||||
|
self::initIfNotExists('LD', 'ld.gold');
|
||||||
|
} else {
|
||||||
|
$arch = arch2gnu(php_uname('m'));
|
||||||
|
self::initIfNotExists('CC', "{$arch}-linux-musl-gcc");
|
||||||
|
self::initIfNotExists('CXX', "{$arch}-linux-musl-g++");
|
||||||
|
self::initIfNotExists('AR', "{$arch}-linux-musl-ar");
|
||||||
|
self::initIfNotExists('LD', 'ld.gold');
|
||||||
|
self::putenv("PATH=/usr/local/musl/bin:/usr/local/musl/{$arch}-linux-musl/bin:" . getenv('PATH'));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Init arch-specific cflags
|
||||||
|
self::initIfNotExists('SPC_DEFAULT_C_FLAGS', '');
|
||||||
|
self::initIfNotExists('SPC_DEFAULT_CXX_FLAGS', '');
|
||||||
|
self::initIfNotExists('SPC_EXTRA_LIBS', '');
|
||||||
|
|
||||||
|
// Init linux-only env
|
||||||
|
self::initIfNotExists('UPX_EXEC', PKG_ROOT_PATH . '/bin/upx');
|
||||||
|
self::initIfNotExists('GNU_ARCH', arch2gnu(php_uname('m')));
|
||||||
|
|
||||||
|
// optimization flags with different strip option
|
||||||
|
$php_extra_cflags_optimize = $builder->getOption('no-strip') ? '-g -O0' : '-g -Os';
|
||||||
|
// optimization flags with different c compiler
|
||||||
|
$clang_use_lld = str_ends_with(getenv('CC'), 'clang') && LinuxSystemUtil::findCommand('lld') ? '-Xcompiler -fuse-ld=lld ' : '';
|
||||||
|
|
||||||
|
$init_spc_cmd_maps = [
|
||||||
|
// Init default build command prefix
|
||||||
|
'SPC_CMD_PREFIX_PHP_BUILDCONF' => './buildconf --force',
|
||||||
|
'SPC_CMD_PREFIX_PHP_CONFIGURE' => $builder->getOption('ld_library_path') . ' ./configure --prefix= --with-valgrind=no --enable-shared=no --enable-static=yes --disable-all --disable-cgi --disable-phpdbg',
|
||||||
|
'SPC_CMD_PREFIX_PHP_MAKE' => 'make -j' . getenv('SPC_CONCURRENCY'),
|
||||||
|
// Init default build vars for build command
|
||||||
|
'SPC_CMD_VAR_PHP_CONFIGURE_CFLAGS' => getenv('SPC_DEFAULT_C_FLAGS'),
|
||||||
|
'SPC_CMD_VAR_PHP_CONFIGURE_CPPFLAGS' => '-I' . BUILD_INCLUDE_PATH,
|
||||||
|
'SPC_CMD_VAR_PHP_CONFIGURE_LDFLAGS' => '-L' . BUILD_LIB_PATH,
|
||||||
|
'SPC_CMD_VAR_PHP_CONFIGURE_LIBS' => '-ldl -lpthread',
|
||||||
|
'SPC_CMD_VAR_PHP_MAKE_EXTRA_CFLAGS' => $php_extra_cflags_optimize . ' -fno-ident -fPIE',
|
||||||
|
'SPC_CMD_VAR_PHP_MAKE_EXTRA_LIBS' => '',
|
||||||
|
'SPC_CMD_VAR_PHP_MAKE_EXTRA_LDFLAGS_PROGRAM' => $clang_use_lld . '-all-static',
|
||||||
|
];
|
||||||
|
|
||||||
|
foreach ($init_spc_cmd_maps as $name => $value) {
|
||||||
|
self::initIfNotExists($name, $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
self::initUnixEnv($builder);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function initDarwinEnv(BuilderBase $builder): void
|
||||||
|
{
|
||||||
|
// Init C Compiler and C++ Compiler
|
||||||
|
self::initIfNotExists('CC', 'clang');
|
||||||
|
self::initIfNotExists('CXX', 'clang++');
|
||||||
|
|
||||||
|
// Init arch-specific cflags
|
||||||
|
self::initIfNotExists('SPC_DEFAULT_C_FLAGS', match (php_uname('m')) {
|
||||||
|
'arm64', 'aarch64' => '--target=arm64-apple-darwin',
|
||||||
|
default => '--target=x86_64-apple-darwin',
|
||||||
|
});
|
||||||
|
// Init arch-specific cxxflags
|
||||||
|
self::initIfNotExists('SPC_DEFAULT_CXX_FLAGS', match (php_uname('m')) {
|
||||||
|
'arm64', 'aarch64' => '--target=arm64-apple-darwin',
|
||||||
|
default => '--target=x86_64-apple-darwin',
|
||||||
|
});
|
||||||
|
|
||||||
|
// Init extra libs (will be appended before `before-php-buildconf` event point)
|
||||||
|
self::initIfNotExists('SPC_EXTRA_LIBS', '');
|
||||||
|
|
||||||
|
$init_spc_cmd_maps = [
|
||||||
|
// Init default build command prefix
|
||||||
|
'SPC_CMD_PREFIX_PHP_BUILDCONF' => './buildconf --force',
|
||||||
|
'SPC_CMD_PREFIX_PHP_CONFIGURE' => './configure --prefix= --with-valgrind=no --enable-shared=no --enable-static=yes --disable-all --disable-cgi --disable-phpdbg',
|
||||||
|
'SPC_CMD_PREFIX_PHP_MAKE' => 'make -j' . getenv('SPC_CONCURRENCY'),
|
||||||
|
// Init default build vars for build command
|
||||||
|
'SPC_CMD_VAR_PHP_CONFIGURE_CFLAGS' => getenv('SPC_DEFAULT_C_FLAGS') . ' -Werror=unknown-warning-option',
|
||||||
|
'SPC_CMD_VAR_PHP_CONFIGURE_CPPFLAGS' => '-I' . BUILD_INCLUDE_PATH,
|
||||||
|
'SPC_CMD_VAR_PHP_CONFIGURE_LDFLAGS' => '-L' . BUILD_LIB_PATH,
|
||||||
|
'SPC_CMD_VAR_PHP_MAKE_EXTRA_CFLAGS' => $builder->getOption('no-strip') ? '-g -O0' : '-g -Os',
|
||||||
|
'SPC_CMD_VAR_PHP_MAKE_EXTRA_LIBS' => '-lresolv',
|
||||||
|
];
|
||||||
|
foreach ($init_spc_cmd_maps as $name => $value) {
|
||||||
|
self::initIfNotExists($name, $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
self::initUnixEnv($builder);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function initUnixEnv(BuilderBase $builder): void
|
||||||
|
{
|
||||||
|
self::putenv('PATH=' . BUILD_ROOT_PATH . '/bin:' . getenv('PATH'));
|
||||||
|
self::putenv('PKG_CONFIG=' . BUILD_BIN_PATH . '/pkg-config');
|
||||||
|
self::putenv('PKG_CONFIG_PATH=' . BUILD_ROOT_PATH . '/lib/pkgconfig');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the environment variable if it does not exist
|
||||||
|
*
|
||||||
|
* @param string $name Environment variable name
|
||||||
|
* @param string $value Environment variable value
|
||||||
|
*/
|
||||||
|
private static function initIfNotExists(string $name, string $value): void
|
||||||
|
{
|
||||||
|
if (($val = getenv($name)) === false) {
|
||||||
|
self::putenv($name . '=' . $value);
|
||||||
|
} else {
|
||||||
|
logger()->debug("env [{$name}] existing: {$val}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function putenv(string $val): void
|
||||||
|
{
|
||||||
|
f_putenv($val);
|
||||||
|
self::$env_cache[] = $val;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -62,7 +62,12 @@ class UnixShell
|
|||||||
|
|
||||||
public function setEnv(array $env): UnixShell
|
public function setEnv(array $env): UnixShell
|
||||||
{
|
{
|
||||||
$this->env = array_merge($this->env, $env);
|
foreach ($env as $k => $v) {
|
||||||
|
if ($v === '') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$this->env[$k] = $v;
|
||||||
|
}
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user