mirror of
https://github.com/crazywhalecc/static-php-cli.git
synced 2026-03-18 04:44:53 +08:00
more merge stuff
This commit is contained in:
parent
958fd0cdcb
commit
22bec873a8
@ -189,6 +189,9 @@
|
|||||||
"static-libs-unix": [
|
"static-libs-unix": [
|
||||||
"libgrpc.a"
|
"libgrpc.a"
|
||||||
],
|
],
|
||||||
|
"pkg-configs": [
|
||||||
|
"grpc"
|
||||||
|
],
|
||||||
"lib-depends": [
|
"lib-depends": [
|
||||||
"zlib",
|
"zlib",
|
||||||
"openssl",
|
"openssl",
|
||||||
|
|||||||
@ -9,6 +9,7 @@ use SPC\builder\windows\WindowsBuilder;
|
|||||||
use SPC\store\FileSystem;
|
use SPC\store\FileSystem;
|
||||||
use SPC\util\CustomExt;
|
use SPC\util\CustomExt;
|
||||||
use SPC\util\GlobalEnvManager;
|
use SPC\util\GlobalEnvManager;
|
||||||
|
use SPC\util\SPCConfigUtil;
|
||||||
use SPC\util\SPCTarget;
|
use SPC\util\SPCTarget;
|
||||||
|
|
||||||
#[CustomExt('grpc')]
|
#[CustomExt('grpc')]
|
||||||
@ -40,37 +41,17 @@ class grpc extends Extension
|
|||||||
|
|
||||||
public function patchBeforeConfigure(): bool
|
public function patchBeforeConfigure(): bool
|
||||||
{
|
{
|
||||||
$libs = join(' ', $this->getLibraries());
|
$util = new SPCConfigUtil($this->builder);
|
||||||
|
$config = $util->config(['grpc']);
|
||||||
|
$libs = $config['libs'];
|
||||||
FileSystem::replaceFileStr(SOURCE_PATH . '/php-src/configure', '-lgrpc', $libs);
|
FileSystem::replaceFileStr(SOURCE_PATH . '/php-src/configure', '-lgrpc', $libs);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function patchBeforeMake(): bool
|
public function patchBeforeMake(): bool
|
||||||
{
|
{
|
||||||
$extra_libs = trim(getenv('SPC_EXTRA_LIBS'));
|
|
||||||
$libs = array_map(function (string $lib) {
|
|
||||||
if (str_starts_with($lib, '-l')) {
|
|
||||||
$staticLib = substr($lib, 2);
|
|
||||||
$staticLib = BUILD_LIB_PATH . '/lib' . $staticLib . '.a';
|
|
||||||
if (file_exists($staticLib)) {
|
|
||||||
return $staticLib;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return $lib;
|
|
||||||
}, $this->getLibraries());
|
|
||||||
$extra_libs = str_replace(BUILD_LIB_PATH . '/libgrpc.a', join(' ', $libs), $extra_libs);
|
|
||||||
f_putenv('SPC_EXTRA_LIBS=' . $extra_libs);
|
|
||||||
// add -Wno-strict-prototypes
|
// add -Wno-strict-prototypes
|
||||||
GlobalEnvManager::putenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_CFLAGS=' . getenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_CFLAGS') . ' -Wno-strict-prototypes');
|
GlobalEnvManager::putenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_CFLAGS=' . getenv('SPC_CMD_VAR_PHP_MAKE_EXTRA_CFLAGS') . ' -Wno-strict-prototypes');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getLibraries(): array
|
|
||||||
{
|
|
||||||
$libs = shell()->execWithResult('$PKG_CONFIG --libs --static grpc')[1][0];
|
|
||||||
$filtered = preg_replace('/-L\S+/', '', $libs);
|
|
||||||
$filtered = preg_replace('/(?:\S*\/)?lib([a-zA-Z0-9_+-]+)\.a\b/', '-l$1', $filtered);
|
|
||||||
$out = preg_replace('/\s+/', ' ', $filtered);
|
|
||||||
return explode(' ', trim($out));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user