php-ds / ext-ds
An extension providing efficient internal data structures as an alterantive to arrays
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2 125
Watchers: 86
Forks: 97
Open Issues: 26
Language:C
Type:php-ext
Requires (Dev)
- php-ds/tests: ^1.5
This package is auto-updated.
Last update: 2025-06-19 17:23:36 UTC
README
A PHP language extension that provides specialized data structures as efficient alternatives to the PHP array. You can read about it in more detail in this blog post which highlights the API, performance (relative to PHP 7) and other benefits of using the extension.
Documentation
Documentation is available on php.net. You should also include the polyfill in your project for IDE integration.
Installation
The easiest way to install the extension is to use PECL:
pecl install ds
If you're on Windows, you can download a compiled .dll
on PECL or under releases.
Enabling the extension
You'll need to add extension=ds.so
to your primary php.ini
file.
If you encounter an "undefined symbol" error, see #2.
# To see where .ini files are located php -i | grep "\.ini"
You can also enable the extension temporarily using the command line:
php -d extension=ds.so
Note: Windows would use php_ds.dll
instead.
Testing
There is a suite of PHPUnit tests that can be installed using Composer.
composer install # Install the test suite composer test # Run the tests composer memtest # Run the tests checking for memory leaks
Compatibility
You may include the polyfill as a dependency in your project. This allows your codebase to still function in an environment where the extension is not installed.
Contributing
For local development, I'm using Docker:
./dev.sh # opens a shell into a development environment
phpize
./configure
make
make install
composer install
composer test
Please see CONTRIBUTING for more information.
Credits
License
The MIT License (MIT). Please see LICENSE for more information.