blob: d6c91184c78bd674aecfc226241445b4b2b0f39a [file] [log] [blame] [view]
Petr Hosek567ac712018-05-30 15:55:16 -07001# GN
2
Scott Grahamab123de2018-06-08 15:53:07 -07003GN is a meta-build system that generates build files for
Brett Wilsonfc2f07a2019-09-03 12:06:18 -07004[Ninja](https://ninja-build.org).
5
6Related resources:
7
Brett Wilson2a181332020-03-20 13:38:18 -07008 * Documentation in [docs/](https://gn.googlesource.com/gn/+/master/docs/). In
Venkatesh Srinivasa38ba1c2020-04-02 11:29:47 -04009 particular [GN Quick Start
10 guide](https://gn.googlesource.com/gn/+/master/docs/quick_start.md)
Brett Wilson2a181332020-03-20 13:38:18 -070011 and the [reference](https://gn.googlesource.com/gn/+/master/docs/reference.md)
12 (the latter is all builtin help converted to a single file).
Brett Wilsonfc2f07a2019-09-03 12:06:18 -070013 * An introductory [presentation](https://docs.google.com/presentation/d/15Zwb53JcncHfEwHpnG_PoIbbzQ3GQi_cpujYwbpcbZo/edit?usp=sharing).
14 * The [mailing list](https://groups.google.com/a/chromium.org/forum/#!forum/gn-dev).
Scott Grahamab123de2018-06-08 15:53:07 -070015
Brett Wilson5f30bbf2021-01-25 16:07:26 -080016## What GN is for
17
18GN is currently used as the build system for Chromium, Fuchsia, and related
19projects. Some strengths of GN are:
20
21 * It is designed for large projects and large teams. It scales efficiently to
22 many thousands of build files and tens of thousands of source files.
23
24 * It has a readable, clean syntax. Once a build is set-up, it is generally
25 easy for people with no backround in GN to make basic edits to the build.
26
27 * It is designed for multi-platform projects. It can cleanly express many
28 complicated build variants across different platforms. A single build
29 invocation can target multiple platforms.
30
31 * It supports multiple parallel output directories, each with their own
32 configuration. This allows a developer to maintain builds targeting debug,
33 release, or different platforms in parallel without forced rebuilds when
34 switching.
35
36 * It has a focus on correctness. GN checks for the correct dependencies,
37 inputs, and outputs to the extent possible, and has a number of tools to
38 allow developers to ensure the build evolves as desired (for example, `gn
39 check`, `testonly`, `assert_no_deps`).
40
41 * It has comprehensive build-in help available from the command-line.
42
43Although small projects successfully use GN, the focus on large projects has
44some disadvanages:
45
46 * GN has the goal of being minimally expressive. Although it can be quite
47 flexible, a design goal is to direct members of a large team (who may not
48 have much knowledge about the build) down an easy-to-understand, well-lit
49 path. This isn't necessarily the correct trade-off for smaller projects.
50
51 * The minimal build configuration is relatively heavyweight. There are several
52 files required and the exact way all compilers are linkers are run must be
53 specified in the configuration (see "Examples" below). There is no default
54 compiler configuration.
55
56 * It is not easily composable. GN is designed to compile a single large
57 project with relatively uniform settings and rules. Projects like Chromium
58 do bring together multiple repositories from multiple teams, but the
59 projects must agree on some conventions in the build files to allow this to
60 work.
61
Brett Wilsond7cf6232021-02-02 17:09:07 -080062 * GN is designed with the expectation that the developers building a project
63 want to compile an identical configuration. So while builds can integrate
Brett Wilson5f30bbf2021-01-25 16:07:26 -080064 with the user's environment like the CXX and CFLAGS variables if they want,
65 this is not the default and most project's builds do not do this. The result
66 is that many GN projects do not integrate well with other systems like
67 ebuild.
68
69 * There is no simple release scheme (see "Versioning and distribution" below).
70 Projects are expected to manage the version of GN they require. Getting an
71 appropriate GN binary can be a hurdle for new contributors to a project.
72 Since it is relatively uncommon, it can be more difficult to find
73 information and examples.
74
75GN can generate Ninja build files for C, C++, Rust, Objective C, and Swift
76source on most popular platforms. Other languages can be compiled using the
Brett Wilsond7cf6232021-02-02 17:09:07 -080077general "action" rules which are executed by Python or another scripting
78language (Google does this to compile Java and Go). But because this is not as
79clean, generally GN is only used when the bulk of the build is in one of the
80main built-in languages.
Brett Wilson5f30bbf2021-01-25 16:07:26 -080081
Brett Wilson4c0c60e2019-07-08 15:18:40 -070082## Getting a binary
Scott Grahamab123de2018-06-08 15:53:07 -070083
Petr Hosek1beb0502018-10-24 18:58:39 -070084You can download the latest version of GN binary for
85[Linux](https://chrome-infra-packages.appspot.com/dl/gn/gn/linux-amd64/+/latest),
86[macOS](https://chrome-infra-packages.appspot.com/dl/gn/gn/mac-amd64/+/latest) and
Brett Wilson5f30bbf2021-01-25 16:07:26 -080087[Windows](https://chrome-infra-packages.appspot.com/dl/gn/gn/windows-amd64/+/latest)
88from Google's build infrastructure (see "Versioning and distribution" below for
89how this is expected to work).
Petr Hosek1beb0502018-10-24 18:58:39 -070090
Brett Wilson5f30bbf2021-01-25 16:07:26 -080091Alternatively, you can build GN from source with a C++17 compiler:
Petr Hosek1beb0502018-10-24 18:58:39 -070092
Scott Graham4a2a0682018-06-11 09:28:19 -070093 git clone https://gn.googlesource.com/gn
94 cd gn
Scott Graham74e0a4c2018-06-12 16:01:49 -070095 python build/gen.py
Scott Graham4a2a0682018-06-11 09:28:19 -070096 ninja -C out
Andrew Grieve77d64a32018-09-06 23:19:01 -040097 # To run tests:
98 out/gn_unittests
Scott Graham0c5d9362018-06-26 21:12:17 -070099
100On Windows, it is expected that `cl.exe`, `link.exe`, and `lib.exe` can be found
101in `PATH`, so you'll want to run from a Visual Studio command prompt, or
102similar.
103
104On Linux and Mac, the default compiler is `clang++`, a recent version is
105expected to be found in `PATH`. This can be overridden by setting `CC`, `CXX`,
106and `AR`.
107
Brett Wilson4c0c60e2019-07-08 15:18:40 -0700108## Examples
109
110There is a simple example in [examples/simple_build](examples/simple_build)
111directory that is a good place to get started with the minimal configuration.
112
Wayne Piekarskib0e61462019-11-08 15:55:17 -0800113To build and run the simple example with the default gcc compiler:
114
115 cd examples/simple_build
116 ../../out/gn gen -C out
117 ninja -C out
118 ./out/hello
119
Brett Wilson4c0c60e2019-07-08 15:18:40 -0700120For a maximal configuration see the Chromium setup:
121 * [.gn](https://cs.chromium.org/chromium/src/.gn)
122 * [BUILDCONFIG.gn](https://cs.chromium.org/chromium/src/build/config/BUILDCONFIG.gn)
123 * [Toolchain setup](https://cs.chromium.org/chromium/src/build/toolchain/)
124 * [Compiler setup](https://cs.chromium.org/chromium/src/build/config/compiler/BUILD.gn)
125
126and the Fuchsia setup:
127 * [.gn](https://fuchsia.googlesource.com/fuchsia/+/refs/heads/master/.gn)
128 * [BUILDCONFIG.gn](https://fuchsia.googlesource.com/fuchsia/+/refs/heads/master/build/config/BUILDCONFIG.gn)
129 * [Toolchain setup](https://fuchsia.googlesource.com/fuchsia/+/refs/heads/master/build/toolchain/)
130 * [Compiler setup](https://fuchsia.googlesource.com/fuchsia/+/refs/heads/master/build/config/BUILD.gn)
131
Daniel Bratellf73698e2018-10-19 16:00:05 +0200132## Reporting bugs
133
134If you find a bug, you can see if it is known or report it in the [bug
135database](https://bugs.chromium.org/p/gn/issues/list).
136
Scott Graham0c5d9362018-06-26 21:12:17 -0700137## Sending patches
138
139GN uses [Gerrit](https://www.gerritcodereview.com/) for code review. The short
140version of how to patch is:
141
Erik Chenc4b86552018-08-22 16:30:36 -0700142 Register at https://gn-review.googlesource.com.
143
Scott Graham0c5d9362018-06-26 21:12:17 -0700144 ... edit code ...
145 ninja -C out && out/gn_unittests
146
147Then, to upload a change for review:
148
149 git commit
Wink Saville84843c52019-11-08 15:59:06 -0800150 git push origin HEAD:refs/for/master
Scott Graham0c5d9362018-06-26 21:12:17 -0700151
Brett Wilsone67b81b2020-01-03 07:56:19 -0800152The first time you do this you'll get an error from the server about a missing
153change-ID. Follow the directions in the error message to install the change-ID
154hook and run `git commit --amend` to apply the hook to the current commit.
155
Scott Graham0c5d9362018-06-26 21:12:17 -0700156When revising a change, use:
157
158 git commit --amend
Wink Saville84843c52019-11-08 15:59:06 -0800159 git push origin HEAD:refs/for/master
Scott Graham0c5d9362018-06-26 21:12:17 -0700160
161which will add the new changes to the existing code review, rather than creating
162a new one.
163
Dirk Prankecad6b532018-07-23 14:02:13 -0700164We ask that all contributors
165[sign Google's Contributor License Agreement](https://cla.developers.google.com/)
166(either individual or corporate as appropriate, select 'any other Google
167project').
168
169## Community
170
Brett Wilson4c0c60e2019-07-08 15:18:40 -0700171You may ask questions and follow along with GN's development on Chromium's
Dirk Prankecad6b532018-07-23 14:02:13 -0700172[gn-dev@](https://groups.google.com/a/chromium.org/forum/#!forum/gn-dev)
173Google Group.
Brett Wilson5f30bbf2021-01-25 16:07:26 -0800174
175## Versioning and distribution
176
Brett Wilsond7cf6232021-02-02 17:09:07 -0800177Most open-source projects are designed to use the developer's computer's current
178toolchain such as compiler, linker, and build tool. But the large
179centrally controlled projects that GN is designed for typically want a more
180hermetic environment. They will ensure that developers are using a specific
181compatible toolchain that is versioned with the code
Brett Wilson5f30bbf2021-01-25 16:07:26 -0800182
183As a result, GN expects that the project choose the appropriate version of GN
184that will work with each version of the project. There is no "current stable
185version" of GN that is expected to work for all projects.
186
187As a result, the GN developers to not maintain any packages in any of the
188various packaging systems (Debian, RedHat, HomeBrew, etc.). Some of these
189systems to have GN packages, but they are maintained by third parties and you
190should use at your own risk. Instead, we recommend you refer your checkout
191tooling to download binaries for a specific hash from [Google's build
192infrastructure](https://chrome-infra-packages.appspot.com/p/gn/gn) or compile
193your own.
194
195GN does not guarantee the backwards-compatibility of new versions and has no
196branches or versioning scheme beyond the sequence of commits to the master git
197branch (which is expected to be stable).
198
199In practice, however, GN is very backwards-compatible. The core functionality
200has been stable for many years and there is enough GN code at Google alone to
201make non-backwards-compatible changes very difficult, even if they were
202desirable.
203
204There have been discussions about adding a versioning scheme with some
205guarantees about backwards-compatibility, but nothing has yet been implemented.