Skip to content

Files

Latest commit

 

History

History
46 lines (28 loc) · 1.18 KB

README.md

File metadata and controls

46 lines (28 loc) · 1.18 KB

Rust and PHP Extension Example

Docker Setup

There is a docker container that is fully setup here: https://registry.hub.docker.com/u/hjr3/rust-php-ext/

To see this in action, simply run: docker run -it -v $(pwd):/source hjr3/rust-php-ext php -d extension=/source/php-ext/modules/score.so -r "var_dump(score('vim', 'vi'));"

Manual Setup

Rust

To build the Rust library:

$ cd rust
$ cargo build

PHP

To build the PHP extension:

$ cd php-ext
$ phpize
$ ./configure --with-score=../rust/target/debug
$ make

You can optionally make install if you want to install the PHP extension shared object.

There are other ways to configure the PHP extension. My blog post has more details.

Run Example

Once the Rust library is built and the PHP extension is compiled, you can see it in action using:

$ php -d extension=php-ext/modules/score.so -r "var_dump(score('vim', 'vi'));"

The -d option tells PHP that we are passing an ini option to look for the score.so shared object at the specified path. The -r option tells PHP to run the code within quotes.