electron/docs/development/build-instructions-linux.md

250 lines
7.3 KiB
Markdown
Raw Normal View History

2015-08-31 05:30:12 +00:00
# Build Instructions (Linux)
Follow the guidelines below for building Electron on Linux.
2014-02-20 10:39:24 +00:00
## Prerequisites
* At least 25GB disk space and 8GB RAM.
* Python 2.7.x. Some distributions like CentOS 6.x still use Python 2.6.x
2015-08-31 05:30:12 +00:00
so you may need to check your Python version with `python -V`.
Please also ensure that your system and Python version support at least TLS 1.2.
For a quick test, run the following script:
```sh
$ python ./script/tls.py
```
If the script returns that your configuration is using an outdated security
protocol, use your system's package manager to update Python to the latest
version in the 2.7.x branch. Alternatively, visit https://www.python.org/downloads/
for detailed instructions.
* Node.js. There are various ways to install Node. You can download
source code from [nodejs.org](https://nodejs.org) and compile it.
2015-08-31 05:30:12 +00:00
Doing so permits installing Node on your own home directory as a standard user.
Or try repositories such as [NodeSource](https://nodesource.com/blog/nodejs-v012-iojs-and-the-nodesource-linux-repositories).
2017-07-27 17:29:41 +00:00
* [clang](https://clang.llvm.org/get_started.html) 3.4 or later.
2015-08-31 05:30:12 +00:00
* Development headers of GTK+ and libnotify.
On Ubuntu, install the following libraries:
2017-11-24 10:13:57 +00:00
```sh
2018-02-15 21:08:55 +00:00
$ sudo apt-get install build-essential clang libdbus-1-dev libgtk-3-dev \
libnotify-dev libgnome-keyring-dev libgconf2-dev \
libasound2-dev libcap-dev libcups2-dev libxtst-dev \
libxss1 libnss3-dev gcc-multilib g++-multilib curl \
gperf bison
```
On RHEL / CentOS, install the following libraries:
2017-11-24 10:13:57 +00:00
```sh
2018-02-15 21:08:55 +00:00
$ sudo yum install clang dbus-devel gtk3-devel libnotify-devel \
libgnome-keyring-devel xorg-x11-server-utils libcap-devel \
cups-devel libXtst-devel alsa-lib-devel libXrandr-devel \
GConf2-devel nss-devel
```
On Fedora, install the following libraries:
2017-11-24 10:13:57 +00:00
```sh
2018-02-15 21:08:55 +00:00
$ sudo dnf install clang dbus-devel gtk3-devel libnotify-devel \
libgnome-keyring-devel xorg-x11-server-utils libcap-devel \
cups-devel libXtst-devel alsa-lib-devel libXrandr-devel \
GConf2-devel nss-devel
```
2015-07-02 07:54:14 +00:00
Other distributions may offer similar packages for installation via package
managers such as pacman. Or one can compile from source code.
2015-08-31 05:30:12 +00:00
## Getting the Code
2014-02-20 10:39:24 +00:00
2017-11-24 10:13:57 +00:00
```sh
2017-07-27 17:29:41 +00:00
$ git clone https://github.com/electron/electron
2014-02-20 10:39:24 +00:00
```
## Bootstrapping
The bootstrap script will download all necessary build dependencies and create
2015-08-31 05:30:12 +00:00
the build project files. You must have Python 2.7.x for the script to succeed.
Downloading certain files can take a long time. Notice that we are using
2015-06-05 01:03:45 +00:00
`ninja` to build Electron so there is no `Makefile` generated.
2014-02-20 10:39:24 +00:00
2017-11-24 10:13:57 +00:00
```sh
2015-04-16 03:31:12 +00:00
$ cd electron
2017-07-27 17:29:41 +00:00
$ ./script/bootstrap.py --verbose
2014-02-20 10:39:24 +00:00
```
If you are using editor supports [JSON compilation database](http://clang.llvm.org/docs/JSONCompilationDatabase.html) based
language server, you can generate it:
```sh
$ ./script/build.py --compdb
```
2015-07-02 07:54:14 +00:00
### Cross compilation
2015-08-31 05:30:12 +00:00
If you want to build for an `arm` target you should also install the following
dependencies:
2017-11-24 10:13:57 +00:00
```sh
$ sudo apt-get install libc6-dev-armhf-cross linux-libc-dev-armhf-cross \
g++-arm-linux-gnueabihf
```
Similarly for `arm64`, install the following:
2017-11-24 10:13:57 +00:00
```sh
$ sudo apt-get install libc6-dev-arm64-cross linux-libc-dev-arm64-cross \
g++-aarch64-linux-gnu
```
2017-07-27 17:29:41 +00:00
And to cross-compile for `arm` or `ia32` targets, you should pass the
2015-07-02 07:54:14 +00:00
`--target_arch` parameter to the `bootstrap.py` script:
2017-11-24 10:13:57 +00:00
```sh
2015-07-02 07:54:14 +00:00
$ ./script/bootstrap.py -v --target_arch=arm
```
2014-02-20 10:39:24 +00:00
## Building
2015-06-05 01:03:45 +00:00
If you would like to build both `Release` and `Debug` targets:
2014-02-20 10:39:24 +00:00
2017-11-24 10:13:57 +00:00
```sh
2014-02-20 10:39:24 +00:00
$ ./script/build.py
```
2015-06-05 01:03:45 +00:00
This script will cause a very large Electron executable to be placed in
2015-07-02 07:54:14 +00:00
the directory `out/R`. The file size is in excess of 1.3 gigabytes. This
happens because the Release target binary contains debugging symbols.
2015-06-05 01:03:45 +00:00
To reduce the file size, run the `create-dist.py` script:
2017-11-24 10:13:57 +00:00
```sh
2015-06-05 01:03:45 +00:00
$ ./script/create-dist.py
```
2015-07-02 07:54:14 +00:00
This will put a working distribution with much smaller file sizes in
2017-07-27 17:29:41 +00:00
the `dist` directory. After running the `create-dist.py` script, you
2015-08-31 05:30:12 +00:00
may want to remove the 1.3+ gigabyte binary which is still in `out/R`.
2015-06-05 01:03:45 +00:00
You can also build the `Debug` target only:
2014-02-20 10:39:24 +00:00
2017-11-24 10:13:57 +00:00
```sh
2015-04-10 13:56:02 +00:00
$ ./script/build.py -c D
2014-02-20 10:39:24 +00:00
```
2015-07-02 07:54:14 +00:00
After building is done, you can find the `electron` debug binary under `out/D`.
## Cleaning
To clean the build files:
2017-11-24 10:13:57 +00:00
```sh
$ npm run clean
```
2017-03-17 18:47:20 +00:00
To clean only `out` and `dist` directories:
2017-11-24 10:13:57 +00:00
```sh
$ npm run clean-build
```
**Note:** Both clean commands require running `bootstrap` again before building.
2014-02-20 10:39:24 +00:00
## Troubleshooting
2015-08-31 05:30:12 +00:00
### Error While Loading Shared Libraries: libtinfo.so.5
2017-06-19 15:45:06 +00:00
Prebuilt `clang` will try to link to `libtinfo.so.5`. Depending on the host
2015-08-31 05:30:12 +00:00
architecture, symlink to appropriate `libncurses`:
2017-11-24 10:13:57 +00:00
```sh
$ sudo ln -s /usr/lib/libncurses.so.5 /usr/lib/libtinfo.so.5
```
2014-02-20 10:39:24 +00:00
## Tests
2016-10-06 17:25:33 +00:00
See [Build System Overview: Tests](build-system-overview.md#tests)
## Advanced topics
The default building configuration is targeted for major desktop Linux
2017-07-27 17:29:41 +00:00
distributions. To build for a specific distribution or device, the following
information may help you.
2016-05-02 13:32:43 +00:00
### Building `libchromiumcontent` locally
To avoid using the prebuilt binaries of `libchromiumcontent`, you can build `libchromiumcontent` locally. To do so, follow these steps:
1. Install [depot_tools](https://chromium.googlesource.com/chromium/src/+/master/docs/linux_build_instructions.md#Install)
2. Install [additional build dependencies](https://chromium.googlesource.com/chromium/src/+/master/docs/linux_build_instructions.md#Install-additional-build-dependencies)
3. Fetch the git submodules:
2017-11-24 10:13:57 +00:00
```sh
$ git submodule update --init --recursive
```
4. Pass the `--build_release_libcc` switch to `bootstrap.py` script:
2017-11-24 10:13:57 +00:00
```sh
$ ./script/bootstrap.py -v --build_release_libcc
```
Note that by default the `shared_library` configuration is not built, so you can
only build `Release` version of Electron if you use this mode:
2017-11-24 10:13:57 +00:00
```sh
2016-05-02 13:32:43 +00:00
$ ./script/build.py -c R
```
### Using system `clang` instead of downloaded `clang` binaries
By default Electron is built with prebuilt
2017-07-27 17:29:41 +00:00
[`clang`](https://clang.llvm.org/get_started.html) binaries provided by the
Chromium project. If for some reason you want to build with the `clang`
installed in your system, you can call `bootstrap.py` with `--clang_dir=<path>`
switch. By passing it the build script will assume the `clang` binaries reside
2017-07-27 17:29:41 +00:00
in `<path>/bin/`.
2016-05-02 13:32:43 +00:00
For example if you installed `clang` under `/user/local/bin/clang`:
2017-11-24 10:13:57 +00:00
```sh
$ ./script/bootstrap.py -v --build_release_libcc --clang_dir /usr/local
2016-05-02 13:32:43 +00:00
$ ./script/build.py -c R
```
2017-07-27 17:29:41 +00:00
### Using compilers other than `clang`
2016-05-02 13:32:43 +00:00
To build Electron with compilers like `g++`, you first need to disable `clang`
with `--disable_clang` switch first, and then set `CC` and `CXX` environment
variables to the ones you want.
For example building with GCC toolchain:
2017-11-24 10:13:57 +00:00
```sh
$ env CC=gcc CXX=g++ ./script/bootstrap.py -v --build_release_libcc --disable_clang
2016-05-02 13:32:43 +00:00
$ ./script/build.py -c R
```
### Environment variables
2017-12-13 03:13:41 +00:00
Apart from `CC` and `CXX`, you can also set the following environment variables to
customise the build configuration:
* `CPPFLAGS`
* `CPPFLAGS_host`
* `CFLAGS`
* `CFLAGS_host`
* `CXXFLAGS`
* `CXXFLAGS_host`
* `AR`
* `AR_host`
* `CC`
* `CC_host`
* `CXX`
* `CXX_host`
* `LDFLAGS`
The environment variables have to be set when executing the `bootstrap.py`
2017-12-13 03:13:41 +00:00
script, it won't work in the `build.py` script.