5.5 KiB
V8Js on Windows
The V8Js PHP extension is primarily targeted at Unix platforms, especially GNU/Linux. However it is possible (and supported) to build on Windows, using Microsoft Visual Studio.
Building with MinGW or Cygwin is not officially supported; mainly since Google v8 does not support builds on Cygwin (and building it on Cygwin is currently broken).
Compared to installation on GNU/Linux it's way more tedious to install V8Js on Windows, since you need to compile PHP with all its dependencies beforehand.
You need to have Visual Studio 2015 (aka VC14), make sure to install the C++ compiler (which is not installed by default any longer).
Compiling V8 using GN (required for 5.2 and higher)
Build transcript using GN by @Jan-E
This is how I built V8 5.8.
TL;DR: these are the essential commands for x64.
call git checkout 5.8-lkgr
call gclient sync
call gn gen v5.8\x64.release --args="is_component_build=true is_debug=false v8_use_snapshot=false enable_nacl=false target_cpu=\"x64\"" --ide=vs
cd v5.8\x64.release
msbuild all.sln
Prerequisites:
- VC14 aka VS2015 with the C and C++ compilers. The Community edition suffices.
- The Windows 10 Debugging Tools. If you did not install the Windows 10 SDK together with VC14, you can do a separate download from https://developer.microsoft.com/en-us/windows/hardware/windows-driver-kit => Windows 10 (WinDbg)
My initial setup was a mixture of the Linux & Windows commands at https://www.chromium.org/developers/how-tos/install-depot-tools
D:
cd \
git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git chromium
set path=D:\chromium;%path%
set GYP_MSVS_VERSION=2015
set DEPOT_TOOLS_WIN_TOOLCHAIN=0
set GYP_CHROMIUM_NO_ACTION=0
cd chromium
fetch v8
git stash
Then I ran the following batch script, inside a 'VS2015 x64 Native Tools Command Prompt' (x64) or a 'VS2015 x86 Native Tools Command Prompt' (x86):
D:
cd \chromium\v8
set WindowsSdkDir=C:\Program Files (x86)\Windows Kits\10\
set WindowsSDK_ExecutablePath_x64=C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.6.2 Tools\x64\
set WindowsSDK_ExecutablePath_x86=C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.6.2 Tools\
set path=D:\chromium;%path%
set GYP_MSVS_VERSION=2015
set DEPOT_TOOLS_WIN_TOOLCHAIN=0
set GYP_CHROMIUM_NO_ACTION=0
set xn=x86
if not %platform%x==x set xn=%platform%
if %xn%==X64 set xn=x64
call git checkout 5.8-lkgr
call git pull
call gclient sync
call gn gen v5.8\%xn%.release --args="is_component_build=true is_debug=false v8_use_snapshot=false enable_nacl=false target_cpu=\"%xn%\"" --ide=vs
cd v5.8\%xn%.release
msbuild all.sln /t:clean
msbuild all.sln
pause
unittests
Compiling V8 5.5 (and before)
The Google v8 project already has excellent step-by-step guide on how to build with gyp.
As a short run through:
- Download and install Python (make sure it adds python.exe to PATH during install) from http://www.python.org/download/
- Install Git from https://github.com/msysgit/msysgit/releases/download/Git-1.9.4-preview20140929/Git-1.9.4-preview20140929.exe
- Install Subversion from http://sourceforge.net/projects/win32svn/files/latest/download
Then open a command prompt
git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git
fetch v8
git checkout 4.7.80.25
gclient sync
python build\gyp_v8 -Dcomponent=shared_library -Dv8_use_snapshot=0
CALL "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\bin\vcvars32.bat"
msbuild build\All.sln /m /p:Configuration=Release
(alternatively start build/all.sln
... and build within the Visual Studio GUI)
Compiling PHP
Then follow the build your own PHP on Windows guide on the PHP wiki. Use Visual Studio 2015 with PHP7.
A quick run through:
- install 7Zip from http://downloads.sourceforge.net/sevenzip/7z920-x64.msi
- create directory \php-sdk
- Download http://windows.php.net/downloads/php-sdk/php-sdk-binary-tools-20110915.zip
- ... and unpack to \php-sdk
Open "VS2015 x86 Native Tools Command Prompt"
cd \php-sdk
bin\phpsdk_setvars.bat
bin\phpsdk_buildtree.bat phpdev
mkdir vc14
mkdir vc14\x86
mkdir vc14\x86\deps
mkdir vc14\x86\deps\bin
mkdir vc14\x86\deps\include
mkdir vc14\x86\deps\lib
- download PHP from http://php.net/get/php-7.0.1.tar.gz/from/a/mirror
and unpack to below
\php-sdk\phpdev\vc14\x86
- from
\v8\build\Release\lib
copyicui18n.lib
,icuuc.lib
,v8.lib
,v8_libbase.lib
andv8_libplatform.lib
to deps\lib folder - from
\v8\include
copy all v8*.h files to deps\include folder - copy
v8-platform.h
again to deps\include\include folder - download V8Js and unpack it into a separate directory below
ext
folder - make sure
config.w32
file inside that folder defines version of the compiled v8
(still in "VS2015 x86 Native Tools Command Prompt")
cd \php-sdk\phpdev\vc14\x86\php-7.0.1\
buildconf
configure --disable-all --enable-cli --with-v8js
nmake
After nmake completes the php.exe is in Release_TS\ directory.
In order to try things out in place, copy over icui18n.dll
, icuuc.dll
and
v8.dll
file from \v8\build\Release
folder to
\php-sdk\phpdev\vc14\x86\php-7.0.1\Release_TS\
first.
Then run
Release_TS\php.exe -d extension=php_v8js.dll -d extension_dir=Release_TS\
Alternatively copy all stuff to c:\php\ (including the three DLL files from v8 build).