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

Stefan Siegl 4baf9e93b2 Use v8::ArrayBuffer::Allocator::NewDefaultAllocator if available пре 8 година
tests 09f69caf64 Relax test to work on V8 without i18n support пре 8 година
.gitignore 5ca50f5253 (Commandfile) add code coverage reporting пре 8 година
.travis.yml 189fbf3c76 Add php 7.1 to travis.yml пре 8 година
CREDITS 5ec269877a Add cscott and myself пре 10 година
Commandfile 2dba61f036 (Commandfile) add --tests option пре 8 година
LICENSE 964c571b70 fix license issue пре 11 година
Makefile.frag 397c5f0e09 load ext-dom for test, if available, refs #270 пре 8 година
Makefile.travis 129ada5f79 (Makefile.travis) compile with -Wall -Wno-write-strings -Werror пре 8 година
README.Linux.md 6b7ab04b43 Mention v8js.icudtl_dat_path in README files пре 8 година
README.MacOS.md 6b7ab04b43 Mention v8js.icudtl_dat_path in README files пре 8 година
README.Win32.md 6b7ab04b43 Mention v8js.icudtl_dat_path in README files пре 8 година
README.md 9a149fcd08 Mention integer precission differences, closes #295 пре 8 година
Vagrantfile 3929456a25 (Vagrantfile) install icudtl.dat file пре 8 година
appveyor.yml c3689f2138 (appveyor) Build with PHP 7.1.4 also пре 8 година
config.m4 4baf9e93b2 Use v8::ArrayBuffer::Allocator::NewDefaultAllocator if available пре 8 година
config.w32 ba3f74f45c Fix PHP_V8_EXEC_PATH for Windows build also пре 8 година
package.xml 98c2a6baec Bump version to 1.4.0 пре 8 година
php_v8js.h 288fe4d2a0 PHP Version 5 -> 7 пре 8 година
php_v8js_macros.h 98c2a6baec Bump version to 1.4.0 пре 8 година
v8js_array_access.cc 3e8ef5f684 remove V8JS_TSRMLS_FETCH пре 8 година
v8js_array_access.h 288fe4d2a0 PHP Version 5 -> 7 пре 8 година
v8js_class.cc 4baf9e93b2 Use v8::ArrayBuffer::Allocator::NewDefaultAllocator if available пре 8 година
v8js_class.h f02b44b3f8 make memory_limit a size_t internally пре 8 година
v8js_commonjs.cc 288fe4d2a0 PHP Version 5 -> 7 пре 8 година
v8js_commonjs.h 288fe4d2a0 PHP Version 5 -> 7 пре 8 година
v8js_convert.cc 24bb1761bf remove TSRMLS_DC, TSRMLS_CC пре 8 година
v8js_exceptions.cc 745126b5cb remove left-over TSRM stuff пре 8 година
v8js_exceptions.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC пре 8 година
v8js_generator_export.cc 8287a19c8d Remove conditional compilation of generator support пре 9 година
v8js_generator_export.h 8287a19c8d Remove conditional compilation of generator support пре 9 година
v8js_main.cc 989f0ae82c Add php.ini setting v8js.icudtl_dat_path пре 8 година
v8js_methods.cc 745126b5cb remove left-over TSRM stuff пре 8 година
v8js_object_export.cc 51335bfa17 remove unused variable пре 8 година
v8js_object_export.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC пре 8 година
v8js_timer.cc f02b44b3f8 make memory_limit a size_t internally пре 8 година
v8js_timer.h f02b44b3f8 make memory_limit a size_t internally пре 8 година
v8js_v8.cc 989f0ae82c Add php.ini setting v8js.icudtl_dat_path пре 8 година
v8js_v8.h fb26b5049c include <functional> for std::function пре 8 година
v8js_v8object_class.cc 24bb1761bf remove TSRMLS_DC, TSRMLS_CC пре 8 година
v8js_v8object_class.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC пре 8 година
v8js_variables.cc 3e8ef5f684 remove V8JS_TSRMLS_FETCH пре 8 година

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 \
  out.gn/x64.release/icudtl.dat /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.

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.