Skip to content

php-ds/ext-ds

Folders and files

NameName
Last commit message
Last commit date

Latest commit

da4d2f2 · Dec 27, 2024
Nov 24, 2024
Feb 28, 2024
Feb 21, 2016
Dec 18, 2023
Aug 4, 2017
Oct 9, 2021
Feb 11, 2016
Nov 24, 2024
Aug 8, 2016
Dec 27, 2024
Nov 24, 2024
Dec 19, 2023
Nov 18, 2018
Oct 24, 2020
Dec 18, 2023
Dec 18, 2023
Dec 18, 2023
Dec 19, 2023
Aug 9, 2016
Dec 19, 2023
Oct 12, 2020
Sep 3, 2020
Oct 8, 2018

Repository files navigation

Native Data Structures for PHP

Build Status Build status PECL

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.