# Extension Notes Because it is a static compilation, extensions will not compile 100% perfectly, and different extensions have different requirements for PHP and the environment, which will be listed one by one here. ## curl When using curl to request HTTPS, there may be an `error:80000002:system library::No such file or directory` error. For details on the solution, see [FAQ - Unable to use ssl](../faq/#unable-to-use-ssl). ## phpmicro 1. Only PHP >= 8.0 is supported. ## swoole 1. swoole >= 5.0 Only PHP >= 8.0 is supported. 2. swoole Currently, curl hooks are not supported for PHP 8.0.x (which may be fixed in the future). 3. When compiling, if only `swoole` extension is included, the supported Swoole database coroutine hook will not be fully enabled. If you need to use it, please add the corresponding `swoole-hook-xxx` extension. 4. The `zend_mm_heap corrupted` problem may occur in swoole under some extension combinations. The cause has not yet been found. ## swoole-hook-pgsql swoole-hook-pgsql is not an extension, it's a Hook feature of Swoole. If you use `swoole,swoole-hook-pgsql`, you will enable Swoole's PostgreSQL client and the coroutine mode of the `pdo_pgsql` extension. swoole-hook-pgsql conflicts with the `pdo_pgsql` extension. If you want to use Swoole and `pdo_pgsql`, please delete the pdo_pgsql extension and enable `swoole` and `swoole-hook-pgsql`. This extension contains an implementation of the coroutine environment for `pdo_pgsql`. On macOS systems, `pdo_pgsql` may not be able to connect to the postgresql server normally, please use it with caution. ## swoole-hook-mysql swoole-hook-mysql is not an extension, it's a Hook feature of Swoole. If you use `swoole,swoole-hook-mysql`, you will enable the coroutine mode of Swoole's `mysqlnd` and `pdo_mysql`. ## swoole-hook-sqlite swoole-hook-sqlite is not an extension, it's a Hook feature of Swoole. If you use `swoole,swoole-hook-sqlite`, you will enable the coroutine mode of Swoole's `pdo_sqlite` (Swoole must be 5.1 or above). swoole-hook-sqlite conflicts with the `pdo_sqlite` extension. If you want to use Swoole and `pdo_sqlite`, please delete the pdo_sqlite extension and enable `swoole` and `swoole-hook-sqlite`. This extension contains an implementation of the coroutine environment for `pdo_sqlite`. ## swow 1. Only PHP version >= 8.0 is supported. ## imap 1. Kerberos is not supported 2. ext-imap is not thread safe due to the underlying c-client. It's not possible to use it in --enable-zts builds. 3. Because the extension may be dropped from php, we recommend you look for an alternative implementation, such as [Webklex/php-imap](https://github.com/Webklex/php-imap) ## gd 1. gd Extension relies on more additional Graphics library. By default, using `bin/spc build gd` directly will not support some Graphics library, such as `libjpeg`, `libavif`, etc. Currently, it supports four libraries: `freetype,libjpeg,libavif,libwebp`. Therefore, the following command can be used to introduce them into the gd library: ```bash bin/spc build gd --with-libs=freetype,libjpeg,libavif,libwebp --build-cli ``` ## mcrypt 1. Currently not supported, and this extension will not be supported in the future. [#32](https://github.com/crazywhalecc/static-php-cli/issues/32) ## oci8 1. oci8 is an extension of the Oracle database, because the library on which the extension provided by Oracle does not provide a statically compiled version (`.a`) or source code, and this extension cannot be compiled into php by static linking, so it cannot be supported. ## xdebug 1. Xdebug is a Zend extension. The functions of Xdebug depend on PHP's Zend engine and underlying code. If you want to statically compile it into PHP, you may need a huge amount of patch code, which is not feasible. 2. The macOS platform can compile an xdebug extension under PHP compiled on the same platform, extract the `xdebug.so` file, and then use the `--no-strip` parameter in static-php-cli to retain the debug symbol table and add the `ffi` extension. The compiled `./php` binary can be configured and run by specifying the INI, eg `./php -d 'zend_extension=/path/to/xdebug.so' your-code.php`. ## xml 1. xml includes xml, xmlreader, xmlwriter, xsl, dom, simplexml, etc. When adding xml extensions, it is best to enable these extensions at the same time. 2. libxml is included in xml extension. Enabling xml is equivalent to enabling libxml. ## glfw 1. glfw depends on OpenGL, and linux environment also needs X11, which cannot be linked statically. 2. macOS platform, we can compile and link system builtin OpenGL and related libraries dynamically. ## rar 1. The rar extension currently has a problem when compiling phpmicro with the `common` extension collection in the macOS x86_64 environment. ## pgsql ~~pgsql ssl connection is not compatible with openssl 3.2.0. See:~~ - ~~~~ - ~~~~ - ~~~~ pgsql 16.2 has fixed this bug, now it's working. When pgsql uses SSL connection, there may be `error:80000002:system library::No such file or directory` error, For details on the solution, see [FAQ - Unable to use ssl](../faq/#unable-to-use-ssl). ## openssl When using openssl-based extensions (such as curl, pgsql and other network libraries), there may be an `error:80000002:system library::No such file or directory` error. For details on the solution, see [FAQ - Unable to use ssl](../faq/#unable-to-use-ssl). ## password-argon2 1. password-argon2 is not a standard extension, it is an additional algorithm for the `password_hash` function. 2. On Linux systems, `password-argon2` dependency `libargon2` conflicts with the `libsodium` library. ## ffi 1. Linux not supported yet: Due to limitations of the Linux system, although the ffi extension can be compiled successfully, it cannot be used to load other `so` extensions. The prerequisite for Linux to support loading `so` extensions is dynamic compilation, but dynamic compilation conflicts with the purpose of this project. 2. macOS supports the ffi extension, but errors will occur when some kernels do not contain debugging symbols. 3. Windows x64 supports the ffi extension. ## xhprof The xhprof extension consists of three parts: `xhprof_extension`, `xhprof_html`, `xhprof_libs`. Only `xhprof_extension` is included in the compiled binary. If you need to use xhprof, please download the source code from [pecl.php.net/package/xhprof](http://pecl.php.net/package/xhprof) and specify the `xhprof_libs` and `xhprof_html` paths for use. ## event If you enable event extension on macOS, the `openpty` will be disabled due to issue: - [static-php-cli#335](https://github.com/crazywhalecc/static-php-cli/issues/335) ## parallel Parallel is only supported on PHP 8.0 ZTS and above. ## spx 1. The [SPX extension](https://github.com/NoiseByNorthwest/php-spx) only supports NTS mode. 2. SPX does not support Windows, and the official repository does not support static compilation. static-php-cli uses a [modified version](https://github.com/static-php/php-spx).