gecko-dev/servo
Patrick Walton fe1801a960 servo: servo: Allow a render backend to be specified on the command line (-r)
Source-Repo: https://github.com/servo/servo
Source-Revision: 013f747fa87c4b2803a299338fa8775eb775447e
2012-11-09 10:51:02 -08:00
..
mk servo: De-Cairo font handling. 2012-11-08 19:33:57 -08:00
src servo: servo: Allow a render backend to be specified on the command line (-r) 2012-11-09 10:51:02 -08:00
.gitignore servo: Rewrite configure script to be more robust; move autogen.sh logic into configure script. 2012-09-04 16:17:36 -07:00
configure servo: Build skia 2012-11-01 14:00:58 -07:00
Info.plist servo: Build an app bundle on OS X 2012-04-23 17:43:45 -07:00
Makefile.in servo: build: Optimize C++ code in submodules. Closes #157. 2012-10-24 23:05:33 -07:00
README.md servo: Update to Rust 166c10e666634cd2fa8615c65d839d63322a2d5b 2012-11-08 17:26:51 -08:00

The Servo Parallel Browser Project

Servo is a prototype web browser engine written in the Rust language. It is currently developed on OS X and Linux.

Note: Servo always requires a specific version of Rust - building against a released version of Rust will not work, nor will the Rust 'master' branch. The commit below will probably work. If it does not then the topic in #servo might know better.

  • Last known-good Rust commit: 166c10e666634cd2fa8615c65d839d63322a2d5b

Prerequisites

First, you need the Rust compiler, built from the exact commit listed above.

On OS X (homebrew):

brew install https://raw.github.com/Homebrew/homebrew-versions/master/autoconf213.rb
brew install cairo

On OS X (MacPorts):

sudo port install autoconf213 cairo +x11 +quartz

On Debian-based Linuxes:

sudo apt-get install libcairo2-dev libpango1.0-dev autoconf2.13 freeglut3-dev

Building

git clone git://github.com/mozilla/servo.git
cd servo
mkdir -p build && cd build
../configure
make check-servo && make
./servo ../src/test/hello.html

If rustc is not installed then add RUSTC=/path/to/rustc to your make commands.

Build Workarounds

MacPorts

Currently, the Makefile for the rust-azure submodule has hardcoded library paths that assumes cairo has been installed with homebrew or MacPorts. If you have installed cairo via another methods or a different version, you will need to change the library path.

This problem should go away once Issue #40 is fixed, and an externally-built cairo is no longer needed.