2015-01-08 19:28:51 +00:00
|
|
|
Linux
|
|
|
|
=====
|
|
|
|
|
2015-04-28 20:06:54 +00:00
|
|
|
Quickstart
|
|
|
|
----------
|
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
<!--?prettify lang=sh?-->
|
2015-04-28 20:06:54 +00:00
|
|
|
|
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
# Install depot_tools (this provides ninja and git-cl).
|
|
|
|
git clone 'https://chromium.googlesource.com/chromium/tools/depot_tools.git'
|
|
|
|
export PATH="${PWD}/depot_tools:${PATH}"
|
2015-04-28 20:06:54 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
# Get Skia.
|
|
|
|
git clone 'https://skia.googlesource.com/skia'
|
|
|
|
cd skia
|
2015-04-28 20:06:54 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
# Install Dependencies (may require sudo).
|
|
|
|
tools/install_dependencies.sh
|
2015-04-28 20:06:54 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
# Sync, Config, and Build.
|
|
|
|
bin/sync-and-gyp
|
|
|
|
ninja -C out/Debug dm SampleApp
|
2015-04-28 20:06:54 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
# Run DM, the Skia test app.
|
|
|
|
out/Debug/dm
|
2015-04-28 20:06:54 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
# Run SampleApp.
|
|
|
|
out/Debug/SampleApp
|
2015-04-28 20:06:54 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
# Run nanobench, the Skia benchmarking tool.
|
|
|
|
ninja -C out/Release nanobench
|
|
|
|
out/Release/nanobench
|
2015-04-28 20:06:54 +00:00
|
|
|
|
|
|
|
|
2015-09-17 15:28:15 +00:00
|
|
|
<a name="prerequisites"></a>Prerequisites
|
2015-11-13 12:29:59 +00:00
|
|
|
-----------------------------------------
|
2015-01-08 19:28:51 +00:00
|
|
|
|
|
|
|
On a Ubuntu 12.04 (Precise) or Ubuntu 14.04 (Trusty) system, you can run
|
|
|
|
`tools/install_dependencies.sh`, which will install the needed packages. On
|
|
|
|
Ubuntu 12.04, you will need to install the`ninja` build tool separately, which
|
|
|
|
comes with Chromium's `depot_tools`.
|
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
To contribute changes back to Skia, you will need `git-cl`, which
|
|
|
|
comes with Chromium's `depot_tools`.
|
2015-01-08 19:28:51 +00:00
|
|
|
|
|
|
|
(If you use another Linux distribution, please consider contributing back
|
|
|
|
instructions for installing the required packages — we can then incorporate
|
|
|
|
that knowledge into the `tools/install_dependencies.sh` tool.)
|
|
|
|
|
|
|
|
Make sure the following have been installed:
|
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
* [Chromium depot_tools](http://www.chromium.org/developers/how-tos/depottools)
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
* A C++ compiler (typically GCC or Clang) **build-essential** or **clang-3.6**
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
* Python 2.7.x: **python2.7-dev**
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
* The FreeType and Fontconfig font engines: **libfreetype6-dev** and
|
|
|
|
**libfontconfig1-dev**
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
* Mesa OpenGL utility library headers: **libglu1-mesa-dev**
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
* Mesa headers: **mesa-common-dev**
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
* GL, such as **freeglut3-dev**
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
* QT4, used by the [Skia Debugger](/dev/tools/debugger): **libqt4-dev**
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
Check out the source code
|
|
|
|
-------------------------
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
Follow the instructions [here](../download) for downloading the Skia source.
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
Notes
|
|
|
|
-----
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
1. On 32-bit Linux (when `uname -m` is *not* `x86_64`), you will have to
|
|
|
|
explicitly specify the architecture:
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
<!--?prettify lang=sh?-->
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
GYP_DEFINES='skia_arch_type=x86' python bin/sync-and-gyp
|
2015-12-03 17:20:55 +00:00
|
|
|
2. By default, many Linux systems use gcc by default. To use clang you will
|
|
|
|
need to [set the CC and CXX environment variables](/user/tips#gypdefines).
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
Generate build files
|
|
|
|
--------------------
|
2015-01-08 19:28:51 +00:00
|
|
|
|
2015-11-13 12:29:59 +00:00
|
|
|
See [this page for generating build files and run tests](desktop).
|