Skip to content
This repository has been archived by the owner on May 30, 2023. It is now read-only.

PhantomJS 2

Ariya Hidayat edited this page Aug 19, 2014 · 33 revisions

The next version, PhantomJS 2, is still in the development. It will be based on Qt 5.

As of May 2014 it is based on webkit 538.1 (7 months old).

Source code

$ git clone git://github.com/ariya/phantomjs.git
$ cd phantomjs

Building

Warning: Building PhantomJS 2 from source can take a very long time (~30 minutes with 4 parallel compile jobs).

Linux

First, install the following packages: sqlite3 libsqlite3-dev g++ ruby gperf bison flex libfontconfig1 libfontconfig1-dev libicu48 libicu-dev ttf-mscorefonts-installer fontconfig libfreetype6 libssl-dev.

On recent Ubuntu distros, the libicu48 package doesn't exist. You can build it with the following commands:

curl http://download.icu-project.org/files/icu4c/4.8.1.1/icu4c-4_8_1_1-src.tgz -O
tar -xvf icu4c-4_8_1_1-src.tgz
cd icu/source
./configure
make
sudo make install

On Debian-based distro, just run:

$ sudo apt-get install sqlite3 libsqlite3-dev g++ ruby gperf bison flex libfontconfig1 libfontconfig1-dev libicu48 libicu-dev ttf-mscorefonts-installer fontconfig libfreetype6 libssl-dev

On Fedora-based distro (tested on CentOS 6), just run:

$ sudo yum -y install gcc gcc-c++ make flex bison gperf ruby openssl-devel freetype-devel fontconfig-devel libicu-devel sqlite-devel

Then, launch the build:

./build.sh --confirm

NOTE: Using sh, instead of bash explicitly, has been reported to fail on some systems.

Mac OS X

PhantomJS 2 depends on ICU.

If you use Homebrew, just run:

$ brew install fontconfig icu4c
$ brew link fontconfig icu4c (note: you may need to use --force)

If you don't/can't/won't use Homebrew, install ICU like this:

$ curl -O http://download.icu-project.org/files/icu4c/53.1/icu4c-53_1-src.tgz
$ tar xf icu4c-53_1-src.tgz
$ cd icu/source && ./runConfigureICU MacOSX
$ make -j4
$ sudo make install

Then, launch the build:

./build.sh --confirm --qt-config "-I /usr/local/include/ -L /usr/local/lib/"

FreeBSD

You will need to edit build.sh:

  • Add OSTYPE=freebsd
  • Change the two make -j$COMPILE_JOBS lines near the end to call gmake instead of make
  • Follow the Linux instructions above

Windows

NOTE: MSVC2012 is the toolchain currently supported.

After you get the source code, clone this repository to src\qt\3rdparty. This will download all 3rd party libraries, headers, which are needed to build PhantomJS 2 on Windows.

NOTE: Repository contains libraries for MSVC2012. If you need other versions, please let me know (Vitallium) by creating an issue in repository.

NOTE: You must have Perl, Python, and Ruby on PATH.

Use Visual Studio Command Prompt, go to src\qt\qtbase, and run configure.bat. This might fail, but you should get src\qt\qtbase\bin\qmake.exe.

Now you are ready to build. Use Visual Studio Command Prompt and run

build.cmd

from top directory. The results will go into bin.

Further Development

We have two development repositories: KDAB and Vitallium's. We're in the process of merge these two repositories into one.

The main goal before we will create a branch for 2 version is make PhantomJS build on all supported platforms: Linux, OS X and Windows. Those repositories can be found at:

Clone this wiki locally