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

Stefan Siegl 6d5a3a2ea6 Merge pull request #296 from stesie/win64-precission-loss-fixes vor 8 Jahren
tests 346c47b657 skip long_int64 test on 32bit PHP versions vor 8 Jahren
.gitignore cce742a614 add Vagrantfile vor 8 Jahren
.travis.yml 189fbf3c76 Add php 7.1 to travis.yml vor 8 Jahren
CREDITS 5ec269877a Add cscott and myself vor 10 Jahren
LICENSE 964c571b70 fix license issue vor 11 Jahren
Makefile.frag 2b4d41abb1 Remove old-age test.php & samples files vor 9 Jahren
Makefile.travis 28ac5a30ae Fix travis build vor 9 Jahren
README.Linux.md 2ab2549d02 README.Linux.md: Add is_component_build flag to v8gen.py command vor 8 Jahren
README.MacOS.md fa613c5cb2 Update links to old Github repo vor 8 Jahren
README.Win32.md 8d1038415c V8 v5.5+ has three v8*.dll's vor 8 Jahren
README.md fa613c5cb2 Update links to old Github repo vor 8 Jahren
Vagrantfile 299aa6adc2 add vm.box override for vagrant-lxc vor 8 Jahren
appveyor.yml a9bdc32125 (appveyor) add x64 builds vor 8 Jahren
config.m4 77e7338018 Don't try to guess if blob.bin files are needed vor 8 Jahren
config.w32 e3a5b915cb (appveyor) update build assets to 5.8.301.0 vor 8 Jahren
package.xml 2356a898aa Bump version to 1.3.4 vor 8 Jahren
php_v8js.h 3278be8bee Add 'indent-tabs-mode: t' to file variables vor 9 Jahren
php_v8js_macros.h a493919a17 extract function zend_long_to_v8js vor 8 Jahren
v8js.cc 3761657335 update copyright years of changed files vor 8 Jahren
v8js_array_access.cc 3761657335 update copyright years of changed files vor 8 Jahren
v8js_array_access.h 3278be8bee Add 'indent-tabs-mode: t' to file variables vor 9 Jahren
v8js_class.cc 3761657335 update copyright years of changed files vor 8 Jahren
v8js_class.h c459acd1ef Merge remote-tracking branch 'origin/master' into php7 vor 9 Jahren
v8js_commonjs.cc c459acd1ef Merge remote-tracking branch 'origin/master' into php7 vor 9 Jahren
v8js_commonjs.h 3278be8bee Add 'indent-tabs-mode: t' to file variables vor 9 Jahren
v8js_convert.cc a493919a17 extract function zend_long_to_v8js vor 8 Jahren
v8js_exceptions.cc c459acd1ef Merge remote-tracking branch 'origin/master' into php7 vor 9 Jahren
v8js_exceptions.h 3278be8bee Add 'indent-tabs-mode: t' to file variables vor 9 Jahren
v8js_generator_export.cc 8287a19c8d Remove conditional compilation of generator support vor 9 Jahren
v8js_generator_export.h 8287a19c8d Remove conditional compilation of generator support vor 9 Jahren
v8js_methods.cc 3761657335 update copyright years of changed files vor 8 Jahren
v8js_object_export.cc db7c81d4fa v8js_object_export: add size checks + precission down casts vor 8 Jahren
v8js_object_export.h 3278be8bee Add 'indent-tabs-mode: t' to file variables vor 9 Jahren
v8js_timer.cc c459acd1ef Merge remote-tracking branch 'origin/master' into php7 vor 9 Jahren
v8js_timer.h c459acd1ef Merge remote-tracking branch 'origin/master' into php7 vor 9 Jahren
v8js_v8.cc d2c171a83f fix bound check: uint32_t -> int vor 8 Jahren
v8js_v8.h e5f57b7661 move #undef min/max to v8js_v8.h vor 8 Jahren
v8js_v8object_class.cc 4a8c49bfed v8js_v8object_class: add size check + precission down cast vor 8 Jahren
v8js_v8object_class.h c459acd1ef Merge remote-tracking branch 'origin/master' into php7 vor 9 Jahren
v8js_variables.cc cc888029c5 v8js_variable: add size check + precission down cast 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 most distributions still ship the rusty version 3.14, publish years ago, since Node.js requires such an old version.

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 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 5.6.326.12
gclient sync

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

# 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 /opt/v8/lib/
sudo cp -R include/* /opt/v8/include/

Compile V8 versions 5.5 and older (using Gyp)

# Install `build-essential` if you haven't already:
sudo apt install build-essential

# Install `chrpath` for fixing libv8.so's RUNPATH header, if you haven't already:
sudo apt install chrpath

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 4.9.385.28
gclient sync

# Build (with internal snapshots)
export GYPFLAGS="-Dv8_use_external_startup_data=0"

# Force gyp to use system-wide ld.gold
export GYPFLAGS="${GYPFLAGS} -Dlinux_use_bundled_gold=0"

# Compile V8 (using up to 8 CPU cores, requires a lot of RAM, adapt as needed)
make native library=shared snapshot=on -j8

# Install to /opt/v8
sudo mkdir -p /opt/v8/{lib,include}
sudo cp out/native/lib.target/lib*.so /opt/v8/lib/
sudo cp -R include/* /opt/v8/include

# Fix libv8.so's RUNPATH header
sudo chrpath -r '$ORIGIN' /opt/v8/lib/libv8.so

# Install libv8_libplatform.a (V8 >= 5.2.51)
echo -e "create /opt/v8/lib/libv8_libplatform.a\naddlib out/native/obj.target/src/libv8_libplatform.a\nsave\nend" | sudo ar -M

# ... same for V8 < 5.2.51, libv8_libplatform.a is built in tools/gyp directory
echo -e "create /opt/v8/lib/libv8_libplatform.a\naddlib out/native/obj.target/tools/gyp/libv8_libplatform.a\nsave\nend" | sudo ar -M

libv8_libplatform.a should not be copied directly since it's a thin archive, i.e. it contains only pointers to the build objects, which otherwise must not be deleted. The simple mri-script converts the thin archive to a normal archive.

Compile php-v8js itself

cd /tmp
git clone https://github.com/phpv8/v8js.git
cd v8js
phpize
./configure --with-v8js=/opt/v8
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.