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

Peter Kokot 06234e56c3 Replace AC_LANG_SAVE, AC_LANG_CPLUSPLUS and AC_LANG_RESTORE 6 years ago
tests 90b6b31f06 break recursion immediately on PHP <= 7.2 as well 6 years ago
.gitignore ddfb9ec012 Use Docker w/ ubuntu:xenial base image on Travis 7 years ago
.travis.yml b3ddc25db1 build against V8 6.6 on travis, adapt repo path 6 years ago
CREDITS 5ec269877a Add cscott and myself 10 years ago
Commandfile e8fe553bde do parallel build on "vagrant run ... build" 7 years ago
Dockerfile.travis e8fd9589dd build without -Werror on travis 6 years ago
LICENSE 964c571b70 fix license issue 11 years ago
Makefile.frag 397c5f0e09 load ext-dom for test, if available, refs #270 8 years ago
Makefile.travis b3ddc25db1 build against V8 6.6 on travis, adapt repo path 6 years ago
README.Linux.md 748256681f bump example version number to a safe one 7 years ago
README.MacOS.md 6b7ab04b43 Mention v8js.icudtl_dat_path in README files 8 years ago
README.Win32.md 6b7ab04b43 Mention v8js.icudtl_dat_path in README files 8 years ago
README.md 4e8251730f emit warnings on V8 < 6.5.143 also 7 years ago
Vagrantfile cba4eb4cb8 Remove old-age V8 versions from Vagrantfile, refs #345 7 years ago
appveyor.yml 42e907c31e Merge pull request #365 from Jan-E/appveyor_3_tests 6 years ago
config.m4 06234e56c3 Replace AC_LANG_SAVE, AC_LANG_CPLUSPLUS and AC_LANG_RESTORE 6 years ago
config.w32 a5fef18360 CFLAGS_BD_EXT_V8JS /DZEND_WIN32_KEEP_INLINE /UZEND_WIN32_FORCE_INLINE after EXTENSION 7 years ago
package.xml cf5e638315 flag Patrick as active=no 7 years ago
php_v8js.h 288fe4d2a0 PHP Version 5 -> 7 8 years ago
php_v8js_macros.h 0c2b55d802 Add GC_(UN)PROTECT_RECURSION, move (un)protecting outside loops 7 years ago
v8js_array_access.cc 3e8ef5f684 remove V8JS_TSRMLS_FETCH 8 years ago
v8js_array_access.h 288fe4d2a0 PHP Version 5 -> 7 8 years ago
v8js_class.cc 18b79d9004 don't free interned strings, only persistent ones 6 years ago
v8js_class.h 313ad1e258 cleanup: remove no longer needed modules_base from ctx, refs #349 7 years ago
v8js_commonjs.cc 288fe4d2a0 PHP Version 5 -> 7 8 years ago
v8js_commonjs.h 288fe4d2a0 PHP Version 5 -> 7 8 years ago
v8js_convert.cc 90b6b31f06 break recursion immediately on PHP <= 7.2 as well 6 years ago
v8js_exceptions.cc 826aaa689c Change to GC_IS_RECURSIVE for PHP 7.3 7 years ago
v8js_exceptions.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC 8 years ago
v8js_generator_export.cc 096454fdf4 Fix deprecated API calls 8 years ago
v8js_generator_export.h 8287a19c8d Remove conditional compilation of generator support 9 years ago
v8js_main.cc 302bf1d0ff remove v8js.compat_php_exceptions 7 years ago
v8js_methods.cc 313ad1e258 cleanup: remove no longer needed modules_base from ctx, refs #349 7 years ago
v8js_object_export.cc 0c2b55d802 Add GC_(UN)PROTECT_RECURSION, move (un)protecting outside loops 7 years ago
v8js_object_export.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC 8 years ago
v8js_timer.cc 13e0b77015 Fix left-over deprecated API calls. 8 years ago
v8js_timer.h f02b44b3f8 make memory_limit a size_t internally 8 years ago
v8js_v8.cc 13e0b77015 Fix left-over deprecated API calls. 8 years ago
v8js_v8.h fb26b5049c include <functional> for std::function 8 years ago
v8js_v8object_class.cc c7019e3c1a Remove GC_G(gc_active) check 7 years ago
v8js_v8object_class.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC 8 years ago
v8js_variables.cc 3e8ef5f684 remove V8JS_TSRMLS_FETCH 8 years ago

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

# 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.