Skip to content

Commit f0c39c1

Browse files
committed
fix #19871
1 parent 896cf88 commit f0c39c1

File tree

1 file changed

+29
-0
lines changed

1 file changed

+29
-0
lines changed

src/SPC/builder/extension/readline.php

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
use SPC\builder\Extension;
88
use SPC\store\FileSystem;
99
use SPC\util\CustomExt;
10+
use SPC\util\SPCTarget;
1011

1112
#[CustomExt('readline')]
1213
class readline extends Extension
@@ -34,4 +35,32 @@ public function buildUnixShared(): void
3435
}
3536
parent::buildUnixShared();
3637
}
38+
39+
public function patchBeforeMake(): bool
40+
{
41+
if (SPCTarget::getTargetOS() === 'Linux' && SPCTarget::isStatic() && $this->builder->getOption('build-cli')) {
42+
FileSystem::replaceFileStr(
43+
SOURCE_PATH . '/php-src/ext/readline/readline_cli.c',
44+
"/*\n#ifdef COMPILE_DL_READLINE",
45+
"#ifdef COMPILE_DL_READLINE\n/*"
46+
);
47+
FileSystem::replaceFileRegex(
48+
SOURCE_PATH . '/php-src/ext/readline/readline_cli.c',
49+
'/\/\*#else\s+?#define GET_SHELL_CB\(cb\) \(cb\) = php_cli_get_shell_callbacks\(\)\s+#endif\*\//s',
50+
"#else\n#define GET_SHELL_CB(cb) (cb) = php_cli_get_shell_callbacks()\n#endif"
51+
);
52+
} else {
53+
FileSystem::replaceFileStr(
54+
SOURCE_PATH . '/php-src/ext/readline/readline_cli.c',
55+
"#ifdef COMPILE_DL_READLINE\n/*",
56+
"/*\n#ifdef COMPILE_DL_READLINE"
57+
);
58+
FileSystem::replaceFileRegex(
59+
SOURCE_PATH . '/php-src/ext/readline/readline_cli.c',
60+
'/#else\s+?#define GET_SHELL_CB\(cb\) \(cb\) = php_cli_get_shell_callbacks\(\)\s+#endif/s',
61+
"/*#else\n#define GET_SHELL_CB(cb) (cb) = php_cli_get_shell_callbacks()\n#endif*/"
62+
);
63+
}
64+
return false;
65+
}
3766
}

0 commit comments

Comments
 (0)