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

Stefan Siegl fa264c9ec5 define V8_ENABLE_SANDBOX if needed 2 سال پیش
tests bf51bf52a9 document (re-)throwing behaviour from exception filter 2 سال پیش
.dockerignore ac784c797a run sanitize=address build on jenkins 5 سال پیش
.gitignore 3327f2e359 Add configure.ac to .gitignore 6 سال پیش
.travis.yml 1128d7dac6 (travis) build on php7.3 5 سال پیش
CREDITS 5ec269877a Add cscott and myself 10 سال پیش
Commandfile e8fe553bde do parallel build on "vagrant run ... build" 7 سال پیش
Dockerfile.jenkins 6f2eeb2fc0 (jenkins) enable pointer compression conditionally, refs #439 4 سال پیش
Dockerfile.travis 147d087e8a use ppa:stesie/libv8, build against V8 7.1 6 سال پیش
Jenkinsfile ec583e343b (Jenkinsfile) build more versions 4 سال پیش
LICENSE 964c571b70 fix license issue 11 سال پیش
Makefile.frag 397c5f0e09 load ext-dom for test, if available, refs #270 8 سال پیش
Makefile.travis bac8a966ab (travis) use v8 7.5 5 سال پیش
README.Linux.md cb96e6e6cb mention pointer compression in README, closes #439 4 سال پیش
README.MacOS.md e13e7a7330 Update README.MacOS.md 7 سال پیش
README.Win32.md 22a6d35459 declare windows as officially unsupported (since currently broken anyways) 5 سال پیش
README.md dd536bc5ce Merge pull request #487 from stesie/exception-proxy-class 2 سال پیش
Vagrantfile 714ae87ab6 (Vagrantfile) provide box w/ php 7.4 5 سال پیش
config.m4 26de750e8e auto-detect V8 sandbox and call InitializeSandbox if needed 2 سال پیش
config.w32 dea7395e57 set v8 version accordingly 6 سال پیش
package.xml ebd2fd865b bump version to 2.1.2 4 سال پیش
php_v8js.h 288fe4d2a0 PHP Version 5 -> 7 8 سال پیش
php_v8js_macros.h fa264c9ec5 define V8_ENABLE_SANDBOX if needed 2 سال پیش
v8js_array_access.cc e648f431ac all test passed v8 8.9 4 سال پیش
v8js_array_access.h ab6e2267af adapt mandatory api changes for V8 7.0.276.3, refs #374 6 سال پیش
v8js_class.cc dd536bc5ce Merge pull request #487 from stesie/exception-proxy-class 2 سال پیش
v8js_class.h 4bfe2ef3ce rename to setExceptionFilter 2 سال پیش
v8js_commonjs.cc 288fe4d2a0 PHP Version 5 -> 7 8 سال پیش
v8js_commonjs.h 288fe4d2a0 PHP Version 5 -> 7 8 سال پیش
v8js_convert.cc e648f431ac all test passed v8 8.9 4 سال پیش
v8js_exceptions.cc 9c45508183 omit use of deprecated apis 6 سال پیش
v8js_exceptions.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC 8 سال پیش
v8js_generator_export.cc 9c45508183 omit use of deprecated apis 6 سال پیش
v8js_generator_export.h 8287a19c8d Remove conditional compilation of generator support 9 سال پیش
v8js_main.cc 32d8dd8dec conditionally call DisposePlatform or ShutdownPlatform 2 سال پیش
v8js_methods.cc dd536bc5ce Merge pull request #487 from stesie/exception-proxy-class 2 سال پیش
v8js_object_export.cc 4bfe2ef3ce rename to setExceptionFilter 2 سال پیش
v8js_object_export.h 7422ef2383 run exceptions thrown in require() through proxy factory as well 2 سال پیش
v8js_timer.cc 13e0b77015 Fix left-over deprecated API calls. 8 سال پیش
v8js_timer.h f02b44b3f8 make memory_limit a size_t internally 8 سال پیش
v8js_v8.cc 26de750e8e auto-detect V8 sandbox and call InitializeSandbox if needed 2 سال پیش
v8js_v8.h e153ff1651 make it compile on PHP 7.3 and 7.4 5 سال پیش
v8js_v8object_class.cc c1d3bda4dc provide get_gc obj handler 2 سال پیش
v8js_v8object_class.h 24bb1761bf remove TSRMLS_DC, TSRMLS_CC 8 سال پیش
v8js_variables.cc 883c9000c3 accessor signature checks are no longer supported 2 سال پیش

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.

Pointer Compression

V8 versions 8.0 and higher enable pointer compression by default. See the design document for details.

Hence if you use one of the recent version (which you really should), then you

a) either need to manually disable pointer compression during

the build of the library by passing the
`v8_enable_pointer_compression=false` flag to `v8gen.py`

b) or compile php-v8js with pointer compression as well, by adding

`CPPFLAGS="-DV8_COMPRESS_POINTERS"` to the `./configure` call.

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 8.0.426.30
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++" CPPFLAGS="-DV8_COMPRESS_POINTERS"
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.