V8 Javascript Engine for PHP — This PHP extension embeds the Google V8 Javascript Engine
fork from : https://github.com/phpv8/v8js.git

Stefan Siegl 83c215d4b1 don't define isnan/isfinite for PHP 7.4 vor 5 Jahren
tests fcd78f830a use EXPECTREGEX to handle different PHP version's output well vor 6 Jahren
.gitignore 3327f2e359 Add configure.ac to .gitignore vor 7 Jahren
.travis.yml 1128d7dac6 (travis) build on php7.3 vor 6 Jahren
CREDITS 5ec269877a Add cscott and myself vor 10 Jahren
Commandfile e8fe553bde do parallel build on "vagrant run ... build" vor 7 Jahren
Dockerfile.travis 147d087e8a use ppa:stesie/libv8, build against V8 7.1 vor 6 Jahren
LICENSE 964c571b70 fix license issue vor 11 Jahren
Makefile.frag 397c5f0e09 load ext-dom for test, if available, refs #270 vor 8 Jahren
Makefile.travis bac8a966ab (travis) use v8 7.5 vor 6 Jahren
README.Linux.md c8be0532f4 Add use_custom_libcxx flag vor 6 Jahren
README.MacOS.md e13e7a7330 Update README.MacOS.md vor 7 Jahren
README.Win32.md 22a6d35459 declare windows as officially unsupported (since currently broken anyways) vor 6 Jahren
README.md cee867f91f Fix Pre-built binaries Docker Hub link vor 5 Jahren
Vagrantfile 714ae87ab6 (Vagrantfile) provide box w/ php 7.4 vor 6 Jahren
config.m4 68d2274297 Handle API removal of CreateDefaultPlatform vor 6 Jahren
config.w32 dea7395e57 set v8 version accordingly vor 6 Jahren
package.xml 1999c703b6 bump version to 2.1.1 vor 6 Jahren
php_v8js.h 288fe4d2a0 PHP Version 5 -> 7 vor 8 Jahren
php_v8js_macros.h 83c215d4b1 don't define isnan/isfinite for PHP 7.4 vor 5 Jahren
v8js_array_access.cc 9c45508183 omit use of deprecated apis vor 6 Jahren
v8js_array_access.h ab6e2267af adapt mandatory api changes for V8 7.0.276.3, refs #374 vor 6 Jahren
v8js_class.cc c2873fd8d3 change retval of write_property handlers, refs #409 vor 6 Jahren
v8js_class.h 35398cc4e3 add zend_class_entry* to method_tmpls key, fixes #410 vor 6 Jahren
v8js_commonjs.cc 288fe4d2a0 PHP Version 5 -> 7 vor 8 Jahren
v8js_commonjs.h 288fe4d2a0 PHP Version 5 -> 7 vor 8 Jahren
v8js_convert.cc 3955409f56 Remove deprecated Context versions of ToBoolean and BooleanValue vor 5 Jahren
v8js_exceptions.cc 9c45508183 omit use of deprecated apis vor 6 Jahren
v8js_exceptions.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC vor 8 Jahren
v8js_generator_export.cc 9c45508183 omit use of deprecated apis vor 6 Jahren
v8js_generator_export.h 8287a19c8d Remove conditional compilation of generator support vor 9 Jahren
v8js_main.cc 302bf1d0ff remove v8js.compat_php_exceptions vor 7 Jahren
v8js_methods.cc 3955409f56 Remove deprecated Context versions of ToBoolean and BooleanValue vor 5 Jahren
v8js_object_export.cc 801c744885 Merge pull request #435 from timothympace/api_updates vor 5 Jahren
v8js_object_export.h ab6e2267af adapt mandatory api changes for V8 7.0.276.3, refs #374 vor 6 Jahren
v8js_timer.cc 13e0b77015 Fix left-over deprecated API calls. vor 8 Jahren
v8js_timer.h f02b44b3f8 make memory_limit a size_t internally vor 8 Jahren
v8js_v8.cc 8fe3cbc292 correctly load V8 8.x snapshot blob vor 5 Jahren
v8js_v8.h 9c45508183 omit use of deprecated apis vor 6 Jahren
v8js_v8object_class.cc 34a18fde06 Merge branch 'php7' of github.com:phpv8/v8js into php-7.4-support vor 5 Jahren
v8js_v8object_class.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC vor 8 Jahren
v8js_variables.cc 3e8ef5f684 remove V8JS_TSRMLS_FETCH vor 8 Jahren

README.Linux.md

V8Js on GNU/Linux

Installation of V8Js on GNU/Linux is pretty much straight forward.

The biggest hurdle actually is that you need a rather new V8 library. However many distributions still ship the rusty version 3.14, published years ago.

This means that you usually need to compile V8 on your own before you can start to compile & install V8Js itself.

It is recommended to install the V8 version for V8Js off your system's load path, so it doesn't interfere with the V8 library shipped with your system's distribution.

Snapshots

V8 has (optional) support for so-called snapshots which speed up startup performance drastically. Hence they are generally recommended for use.

There are two flavours of snapshots: internal & external.

Internal snapshots are built right into the V8 library (libv8.so file), so there's no need to handle them specially.

Besides there are external snapshots (which are enabled unless configured otherwise). If V8 is compiled with these, then V8Js needs to provide two "binary blobs" to V8, named natives_blob.bin and snapshot_blob.bin. In that case copy those two files to the same directory libv8.so was installed to.

Compile V8 5.6 and newer (using GN)

# Install required dependencies
sudo apt-get install build-essential curl git python libglib2.0-dev

cd /tmp

# Install depot_tools first (needed for source checkout)
git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git
export PATH=`pwd`/depot_tools:"$PATH"

# Download v8
fetch v8
cd v8

# (optional) If you'd like to build a certain version:
git checkout 6.4.388.18
gclient sync

# Setup GN
tools/dev/v8gen.py -vv x64.release -- is_component_build=true use_custom_libcxx=false

# Build
ninja -C out.gn/x64.release/

# Install to /opt/v8/
sudo mkdir -p /opt/v8/{lib,include}
sudo cp out.gn/x64.release/lib*.so out.gn/x64.release/*_blob.bin \
  out.gn/x64.release/icudtl.dat /opt/v8/lib/
sudo cp -R include/* /opt/v8/include/

On Debian Stretch you need to set RPATH on the installed libraries, so the library loader finds the dependencies:

sudo apt-get install patchelf
for A in /opt/v8/lib/*.so; do sudo patchelf --set-rpath '$ORIGIN' $A; done

Compile php-v8js itself

cd /tmp
git clone https://github.com/phpv8/v8js.git
cd v8js
phpize
./configure --with-v8js=/opt/v8 LDFLAGS="-lstdc++"
make
make test
sudo make install

Then add extension=v8js.so to your php.ini file. If you have a separate configuration for CLI, add it there also.

V8Js' build system assumes that the icudtl.dat file is located next to the libv8.so library file and compiles the path into the library itself. If for whatever reason the icudtl.dat file is stored at a different place during runtime, you need to set the php.ini variable v8js.icudtl_dat_path to point to the file. Otherwise locale-aware features of V8 will not work as expected.