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

Stefan Siegl 0aa1a6e73e Replace build status badge by Travis one 9 年之前
tests 3d5f163899 skip time/memory limit tests on SKIP_SLOW_TESTS 9 年之前
.gitignore 981f502303 ignore run-tests.php valgrind result files 9 年之前
.travis.yml 6e09930325 Update travis config 9 年之前
CREDITS 5ec269877a Add cscott and myself 10 年之前
LICENSE 964c571b70 fix license issue 11 年之前
Makefile.frag 2b4d41abb1 Remove old-age test.php & samples files 9 年之前
Makefile.travis 4cd9151b5f Fix travis build 9 年之前
README.Linux.md 5fa653da23 Added libicu-dev dependency 9 年之前
README.MacOS.md e5ee35a30e Updated README.MacOS to recommend installing extension via brew 9 年之前
README.Win32.md 14aca623fa Update README.Win32.md 9 年之前
README.md 0aa1a6e73e Replace build status badge by Travis one 9 年之前
config.m4 ed8e88e11d Search libv8_libplatform.a in V8_DIR only 9 年之前
config.w32 dd2ad91452 config.w32: fix v8api version generation, refs #210 9 年之前
package.xml c34fc46ce2 Bump version to 0.6.3 9 年之前
php_v8js.h dc1475a3ad updated package for beta release and switch license to MIT 11 年之前
php_v8js_macros.h c34fc46ce2 Bump version to 0.6.3 9 年之前
v8js.cc 4fea8f4fb9 Require V8 4.6.76 or higher 9 年之前
v8js_array_access.cc 05b96a96b8 Use internal fields instead of GetHiddenValue/SetHiddenValue 9 年之前
v8js_array_access.h 5b4aaa64f1 More php_v8js_ prefix cleanup 10 年之前
v8js_class.cc 05b96a96b8 Use internal fields instead of GetHiddenValue/SetHiddenValue 9 年之前
v8js_class.h 4fea8f4fb9 Require V8 4.6.76 or higher 9 年之前
v8js_commonjs.cc 6bbe4d932b remove useless zero-initializations (immediately overridden afterwards) 9 年之前
v8js_commonjs.h f61c11f995 declare base & identifier const 9 年之前
v8js_convert.cc 05b96a96b8 Use internal fields instead of GetHiddenValue/SetHiddenValue 9 年之前
v8js_exceptions.cc 05b96a96b8 Use internal fields instead of GetHiddenValue/SetHiddenValue 9 年之前
v8js_exceptions.h f7c33539c2 Improve PHP->JS->PHP exception back propagation 9 年之前
v8js_methods.cc b21ba328d0 Don't call ObjectTemplate.Set with Object instances, fixes #230 9 年之前
v8js_object_export.cc ec6c6d3eb3 Use WeakCallbackInfo 9 年之前
v8js_object_export.h 3508f0c8e7 export public methods of classes derived from \V8Js, closes #183 9 年之前
v8js_timer.cc 3dca462e9d Use V8::LowMemoryNotification on V8 < 3.28.36 9 年之前
v8js_timer.h 2954de2db5 Remove php_ prefix to struct & type names 10 年之前
v8js_v8.cc 05b96a96b8 Use internal fields instead of GetHiddenValue/SetHiddenValue 9 年之前
v8js_v8.h 83f51e5021 Merge pull request #156 from stesie/php-exception-behaviour 9 年之前
v8js_v8object_class.cc c804b16e4c fix compiler warnings 9 年之前
v8js_v8object_class.h 294a5c8d1f php_v8js_create_v8 -> v8js_v8object_create 10 年之前
v8js_variables.cc 5b4aaa64f1 More php_v8js_ prefix cleanup 10 年之前

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.

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 /usr/share/v8/....

Compile latest V8

# Install `libicu-dev` if you haven't already:
sudo apt-get install libicu-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 4.9.385.28
gclient sync

# use libicu of operating system
export GYP_DEFINES="use_system_icu=1"

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

make native library=shared snapshot=on -j8

# Install to /usr
sudo mkdir -p /usr/lib /usr/include
sudo cp out/native/lib.target/lib*.so /usr/lib/
sudo cp -R include/* /usr/include

# Install libv8_libplatform.a (V8 >= 5.2.51)
echo -e "create /usr/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 /usr/lib/libv8_libplatform.a\naddlib out/native/obj.target/tools/gyp/libv8_libplatform.a\nsave\nend" | sudo ar -M
  • If you don't want to overwrite the system copy of v8, replace /usr in the above commands with some other path like /opt/v8 and then add --with-v8js=/opt/v8 to the php-v8js ./configure command below.

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