- Notifications
You must be signed in to change notification settings - Fork0
ayushmishra2005/servo
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
Servo is a prototype web browser engine written in theRust language. It is currently developed on64-bit macOS, 64-bit Linux, 64-bit Windows, and Android.
Servo welcomes contribution from everyone. SeeCONTRIBUTING.md
andHACKING_QUICKSTART.md
for help getting started.
Visit theServo Project page for news and guides.
Building servo requiresrustup, version 1.8.0 or more recent.If you have an older version, runrustup self update
.
To install on Windows, download and runrustup-init.exe
then follow the onscreen instructions.
To install on other systems, run:
curl https://sh.rustup.rs -sSf| sh
This will also download the current stable version of Rust, which Servo won’t use.To skip that step, run instead:
curl https://sh.rustup.rs -sSf | sh -s -- --default-toolchain none
See alsoOther installation methods
Please select your operating system:
Xcode version 10.2 or above is recommended.
brew bundle install --file=etc/taskcluster/macos/Brewfilebrew bundle install --file=etc/taskcluster/macos/Brewfile-buildpip install virtualenv
sudo apt install python-virtualenv python-pip./mach bootstrap
If./mach bootstrap
doesn't work, file a bug, and, run the commands below:
sudo apt install git curl autoconf libx11-dev libfreetype6-dev libgl1-mesa-dri \ libglib2.0-dev xorg-dev gperf g++ build-essential cmake libssl-dev \ libbz2-dev liblzma-dev libosmesa6-dev libxmu6 libxmu-dev libglu1-mesa-dev \ libgles2-mesa-dev libegl1-mesa-dev libdbus-1-dev libharfbuzz-dev ccache \ clang libunwind-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev \ libgstreamer-plugins-bad1.0-dev autoconf2.13 llvm-dev
Additionally, you'll need a local copy of GStreamer with a version later than 12.0. You can place it insupport/linux/gstreamer/gst
, or run./mach bootstrap-gstreamer
to set it up.
If you are usingUbuntu 16.04 orLinux Mint 18.* runexport HARFBUZZ_SYS_NO_PKG_CONFIG=1
before building to avoid an error with harfbuzz.
If you get an undefined symbol error ongst_player_get_config
try removinggir1.2-gst-plugins-bad-1.0
and all old versions of clang, see#22016
If you are onUbuntu 14.04 and encountered errors on installing these dependencies involvinglibcheese
, see#6158 for a workaround. You may also need to install gcc 4.9, clang 4.0, and cmake 3.2:
sudo add-apt-repository ppa:ubuntu-toolchain-r/testsudo apt-get updatesudo apt-get install gcc-4.9 g++-4.9sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.9 60 --slave /usr/bin/g++ g++ /usr/bin/g++-4.9
clang 4.0:
wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key| sudo apt-key add -sudo apt-add-repository"deb http://apt.llvm.org/trusty/ llvm-toolchain-trusty-4.0 main"sudo apt-get updatesudo apt-get install -y clang-4.0
cmake 3.2:
sudo apt-get install software-properties-commonsudo add-apt-repository ppa:george-edison55/cmake-3.xsudo apt-get updatesudo apt-get install cmake
sudo dnf install python2 python2-virtualenv python2-pip./mach bootstrap
If./mach bootstrap
doesn't work, file a bug, and, run the commands below:
sudo dnf install curl libtool gcc-c++ libXi-devel libunwind-devel \ freetype-devel mesa-libGL-devel mesa-libEGL-devel glib2-devel libX11-devel \ libXrandr-devel gperf fontconfig-devel cabextract ttmkfdir expat-devel \ rpm-build openssl-devel cmake bzip2-devel libX11-devel libXcursor-devel \ libXmu-devel mesa-libOSMesa-devel dbus-devel ncurses-devel harfbuzz-devel \ ccache mesa-libGLU-devel clang clang-libs gstreamer1-devel \ gstreamer1-plugins-base-devel gstreamer1-plugins-bad-free-devel autoconf213
sudo yum install python-virtualenv python-pip./mach bootstrap
If./mach bootstrap
doesn't work, file a bug, and, run the commands below:
sudo yum install curl libtool gcc-c++ libXi-devel freetype-devel \ mesa-libGL-devel mesa-libEGL-devel glib2-devel libX11-devel libXrandr-devel \ gperf fontconfig-devel cabextract ttmkfdir python expat-devel rpm-build \ openssl-devel cmake3 bzip2-devel libXcursor-devel libXmu-devel \ mesa-libOSMesa-devel dbus-devel ncurses-devel python34 harfbuzz-devel \ ccache clang clang-libs llvm-toolset-7
Build insidellvm-toolset
anddevtoolset
:
sclenable devtoolset-7 llvm-toolset-7 bash
with the following environmental variables set:
export CMAKE=cmake3export LIBCLANG_PATH=/opt/rh/llvm-toolset-7/root/usr/lib64
sudo zypper install libX11-devel libexpat-devel libbz2-devel Mesa-libEGL-devel Mesa-libGL-devel cabextract cmake \ dbus-1-devel fontconfig-devel freetype-devel gcc-c++ git glib2-devel gperf \ harfbuzz-devel libOSMesa-devel libXcursor-devel libXi-devel libXmu-devel libXrandr-devel libopenssl-devel \ python-pip python-virtualenv rpm-build glu-devel ccache llvm-clang libclang autoconf213 gstreamer-devel \ gstreamer-plugins-base-devel gstreamer-plugins-bad-devel
sudo pacman -S --needed base-devel git python2 python2-virtualenv python2-pip mesa cmake bzip2 libxmu glu \ pkg-config ttf-fira-sans harfbuzz ccache llvm clang autoconf2.13 gstreamer gstreamer-vaapi
sudo emerge net-misc/curl \ media-libs/freetype media-libs/mesa dev-util/gperf \ dev-python/virtualenv dev-python/pip dev-libs/openssl \ media-libs/harfbuzz dev-util/ccache sys-libs/libunwind \ x11-libs/libXmu media-libs/glu x11-base/xorg-server sys-devel/clang \ media-libs/gstreamer media-libs/gst-plugins-bad media-libs/gst-plugins-base
With the following environment variable set:
export LIBCLANG_PATH=$(llvm-config --prefix)/lib64
- Install Python 2.7 for Windows (https://www.python.org/downloads/release/python-2716/). The Windows x86-64 MSI installer is fine. This is required for the build system execution and many dependencies.
You should change the installation to install the "Add python.exe to Path" feature.
You will also need to set thePYTHON2
environment variable, e.g., to 'C:\Python27\python.exe' by doing:
setx PYTHON2 "C:\Python27\python.exe" /m
- Install Python 3.7 for Windows (https://www.python.org/downloads/release/python-374/). The Windows x86-64 MSI installer is fine. This is required in order to build the JavaScript engine, SpiderMonkey.
You will also need to set thePYTHON3
environment variable, e.g., to 'C:\Python37\python.exe' by doing:
setx PYTHON3 "C:\Python37\python.exe" /m
The/m
will set it system-wide for all future command windows.
- Install virtualenv.
In a normal Windows Shell (cmd.exe or "Command Prompt" from the start menu), do:
pip install virtualenv
If this does not work, you may need to reboot for the changed PATH settings (by the python installer) to take effect.
- Install the most recentGStreamer MSVC packages. You need to download the two
.msi
files for your platform from theGStreamer website and install them. The currently recommended version is 1.16.0. i.e.:
Note that the MinGW binaries will not work, so make sure that you install the MSVC the ones.
Note that you should ensure thatall components are installed from gstreamer, as we require many of the optional libraries that are not installed by default.
Install Git for Windows (https://git-scm.com/download/win). DO allow it to add git.exe to the PATH (defaultsettings for the installer are fine).
Install Visual Studio Community 2017 (https://www.visualstudio.com/vs/community/). You MUST add "Visual C++" to thelist of installed components as well as the "Windows Universal C runtime." They are not on by default. Visual Studio 2017 MUST installed to the default location or mach.bat will not find it.
Note that version is hard to download online and is easier to install viaChocolatey with:
choco install -y visualstudio2017community --package-parameters="'--add Microsoft.VisualStudio.Component.Git'"Update-SessionEnvironment #refreshing env due to Git install#--- UWP Workload and installing Windows Template Studio ---choco install -y visualstudio2017-workload-nativedesktop
You may experience much faster builds on Windows by following these steps. (Related Rust issue:rust-lang/rust#37543)
- Download the latest version of LLVM (https://releases.llvm.org/).
- Run the installer and choose to add LLVM to the system PATH.
- Add the following to your Cargo config (Found at
%USERPROFILE%\.cargo\config
). You may need to change the triple to match your environment.
[target.x86_64-pc-windows-msvc]linker = "lld-link.exe"
If you encountered errors with the environment above, do the following for a workaround:
- Download and installBuild Tools for Visual Studio 2017
- Install
python2.7 x86-x64
andvirtualenv
- Run
mach.bat build -d
.
If you have troubles with
x64 type
prompt asmach.bat
set by default:
- You may need to choose and launch the type manually, such as
x86_x64 Cross Tools Command Prompt for VS 2017
in the Windows menu.)cd to/the/path/servo
python mach build -d
If you got the error
Cannot run mach in a path on a case-sensitive file system on Windows
:
- Open Command Prompt or PowerShell as administrator.
- Disable case-sensitive for servo path,
fsutil.exe file SetCaseSensitiveInfo X:\path\to\servo disable
If you got the error
DLL file
api-ms-win-crt-runtime-l1-1-0.dllnot found!
then settheWindowsSdkDir
environment variable to an appropriateWindows Kit
directory containingRedist\ucrt\DLLs\x64\api-ms-win-crt-runtime-l1-1-0.dll
, for exampleC:\Program Files (x86)\Windows Kits\10
.
Run./mach bootstrap-android --build
to get Android-specific tools. See wiki fordetails.
Servo's build system uses rustup.rs to automatically download a Rust compiler.This is a specific version of Rust Nightly determined by therust-toolchain
file.
Servo is built withCargo, the Rust package manager. We also use Mozilla'sMach tools to orchestrate the build and other tasks.
To build Servo in development mode. This is useful for development, butthe resulting binary is very slow.
git clone https://github.com/servo/servocd servo./mach build --dev./mach run tests/html/about-mozilla.html
Or on Windows MSVC, in a normal Command Prompt (cmd.exe):
git clone https://github.com/servo/servocd servomach.bat build --dev
For benchmarking, performance testing, orreal-world use, add the--release
flag to create an optimized build:
./mach build --release./mach run --release tests/html/about-mozilla.html
Note:mach build
will build bothservo
andlibsimpleservo
. To make compilation a bit faster, it's possible to only compile the servo binary:./mach build --dev -p servo
.
If you’re making changes to one crate that cause build errors in another crate,consider this instead of a full build:
./mach check
It will runcargo check
, which runs the analysis phase of the compiler(and so shows build errors if any) but skips the code generation phase.This can be a lot faster than a full build,though of course it doesn’t produce a binary you can run.
For ARM (armv7-linux-androideabi
, most phones):
./mach build --release --android./mach package --release --android
For x86 (typically for the emulator):
./mach build --release --target i686-linux-android./mach package --release --target i686-linux-android
Run Servo with the command:
./servo [url] [arguments]# if you run with nightly build./mach run [url] [arguments]# if you run with mach# For example./mach run https://www.google.com
-p INTERVAL
turns on the profiler and dumps info to the console everyINTERVAL
seconds-s SIZE
sets the tile size for painting; defaults to 512-z
disables all graphical output; useful for running JS / layout tests-Z help
displays useful output to debug servo
Ctrl
+L
opens URL prompt (Cmd
+L
on Mac)Ctrl
+R
reloads current page (Cmd
+R
on Mac)Ctrl
+-
zooms out (Cmd
+-
on Mac)Ctrl
+=
zooms in (Cmd
+=
on Mac)Alt
+left arrow
goes backwards in the history (Cmd
+left arrow
on Mac)Alt
+right arrow
goes forwards in the history (Cmd
+right arrow
on Mac)Esc
orCtrl
+Q
exits Servo (Cmd
+Q
on Mac)
There are lots of mach commands you can use. You can list them with./mach --help
.
The generated documentation can be found onhttps://doc.servo.org/servo/index.html
About
The Servo Browser Engine
Resources
License
Stars
Watchers
Forks
Packages0
Languages
- Rust85.0%
- Python10.2%
- WebIDL2.9%
- C++0.7%
- Java0.3%
- Shell0.3%
- Other0.6%