blob: d2de132b15f3aa23b50258b035099794c5ad32fa [file] [log] [blame] [view]
dpranke1a70d0c2016-12-01 02:42:291# Checking out and building Chromium for Android
2
estevenson75e9b862017-01-05 16:49:233There are instructions for other platforms linked from the
dpranke1a70d0c2016-12-01 02:42:294[get the code](get_the_code.md) page.
tfarina2c773222016-04-05 18:43:355
dpranke1a70d0c2016-12-01 02:42:296## Instructions for Google Employees
7
8Are you a Google employee? See
Eric Stevenson36459112018-07-06 20:12:389[go/building-android-chrome](https://goto.google.com/building-android-chrome)
10instead.
dpranke0ae7cad2016-11-30 07:47:5811
tfarina2c773222016-04-05 18:43:3512[TOC]
13
dpranke0ae7cad2016-11-30 07:47:5814## System requirements
tfarina2c773222016-04-05 18:43:3515
dpranke0ae7cad2016-11-30 07:47:5816* A 64-bit Intel machine running Linux with at least 8GB of RAM. More
17 than 16GB is highly recommended.
18* At least 100GB of free disk space.
19* You must have Git and Python installed already.
tfarina2c773222016-04-05 18:43:3520
dpranke0ae7cad2016-11-30 07:47:5821Most development is done on Ubuntu. Other distros may or may not work;
Tom Anderson93e49e492019-12-23 19:55:3722see the [Linux instructions](linux/build_instructions.md) for some suggestions.
tfarina2c773222016-04-05 18:43:3523
dpranke0ae7cad2016-11-30 07:47:5824Building the Android client on Windows or Mac is not supported and doesn't work.
tfarina2c773222016-04-05 18:43:3525
Nate Fischer540458a2019-06-12 20:45:3626## Install depot\_tools
tfarina2c773222016-04-05 18:43:3527
sdy93387fa2016-12-01 01:03:4428Clone the `depot_tools` repository:
dpranke0ae7cad2016-11-30 07:47:5829
sdy93387fa2016-12-01 01:03:4430```shell
Andrew Grievec81af4a2017-07-26 18:02:1331git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git
sdy93387fa2016-12-01 01:03:4432```
dpranke0ae7cad2016-11-30 07:47:5833
sdy93387fa2016-12-01 01:03:4434Add `depot_tools` to the end of your PATH (you will probably want to put this
35in your `~/.bashrc` or `~/.zshrc`). Assuming you cloned `depot_tools`
36to `/path/to/depot_tools`:
dpranke0ae7cad2016-11-30 07:47:5837
sdy93387fa2016-12-01 01:03:4438```shell
Andrew Grievec81af4a2017-07-26 18:02:1339export PATH="$PATH:/path/to/depot_tools"
sdy93387fa2016-12-01 01:03:4440```
dpranke0ae7cad2016-11-30 07:47:5841
42## Get the code
43
sdy93387fa2016-12-01 01:03:4444Create a `chromium` directory for the checkout and change to it (you can call
dpranke0ae7cad2016-11-30 07:47:5845this whatever you like and put it wherever you like, as
46long as the full path has no spaces):
47
sdy93387fa2016-12-01 01:03:4448```shell
Andrew Grievec81af4a2017-07-26 18:02:1349mkdir ~/chromium && cd ~/chromium
50fetch --nohooks android
sdy93387fa2016-12-01 01:03:4451```
dpranke0ae7cad2016-11-30 07:47:5852
53If you don't want the full repo history, you can save a lot of time by
sdy93387fa2016-12-01 01:03:4454adding the `--no-history` flag to `fetch`.
dpranke0ae7cad2016-11-30 07:47:5855
56Expect the command to take 30 minutes on even a fast connection, and many
57hours on slower ones.
58
59If you've already installed the build dependencies on the machine (from another
sdy93387fa2016-12-01 01:03:4460checkout, for example), you can omit the `--nohooks` flag and `fetch`
dpranke0ae7cad2016-11-30 07:47:5861will automatically execute `gclient runhooks` at the end.
62
sdy93387fa2016-12-01 01:03:4463When `fetch` completes, it will have created a hidden `.gclient` file and a
64directory called `src` in the working directory. The remaining instructions
65assume you have switched to the `src` directory:
dpranke0ae7cad2016-11-30 07:47:5866
sdy93387fa2016-12-01 01:03:4467```shell
Andrew Grievec81af4a2017-07-26 18:02:1368cd src
sdy93387fa2016-12-01 01:03:4469```
dpranke0ae7cad2016-11-30 07:47:5870
71### Converting an existing Linux checkout
tfarina2c773222016-04-05 18:43:3572
73If you have an existing Linux checkout, you can add Android support by
Victor Viannae6b228f2022-01-26 14:42:3774appending `target_os = ['linux', 'android']` to your `.gclient` file (in the
sdy93387fa2016-12-01 01:03:4475directory above `src`):
tfarina2c773222016-04-05 18:43:3576
sdy93387fa2016-12-01 01:03:4477```shell
Prakhar5db34ec2024-01-30 19:26:4878echo "target_os = [ 'linux', 'android' ]" >> ../.gclient
sdy93387fa2016-12-01 01:03:4479```
tfarina2c773222016-04-05 18:43:3580
sdy93387fa2016-12-01 01:03:4481Then run `gclient sync` to pull the new Android dependencies:
tfarina2c773222016-04-05 18:43:3582
sdy93387fa2016-12-01 01:03:4483```shell
Andrew Grievec81af4a2017-07-26 18:02:1384gclient sync
sdy93387fa2016-12-01 01:03:4485```
tfarina2c773222016-04-05 18:43:3586
sdy93387fa2016-12-01 01:03:4487(This is the only difference between `fetch android` and `fetch chromium`.)
tfarina2c773222016-04-05 18:43:3588
dpranke0ae7cad2016-11-30 07:47:5889### Install additional build dependencies
tfarina2c773222016-04-05 18:43:3590
dpranke0ae7cad2016-11-30 07:47:5891Once you have checked out the code, run
tfarina2c773222016-04-05 18:43:3592
sdy93387fa2016-12-01 01:03:4493```shell
Ho Cheungfd3ed272023-01-07 02:40:2494build/install-build-deps.sh --android
sdy93387fa2016-12-01 01:03:4495```
tfarina2c773222016-04-05 18:43:3596
sdy93387fa2016-12-01 01:03:4497to get all of the dependencies you need to build on Linux, *plus* all of the
dpranke0ae7cad2016-11-30 07:47:5898Android-specific dependencies (you need some of the regular Linux dependencies
sdy93387fa2016-12-01 01:03:4499because an Android build includes a bunch of the Linux tools and utilities).
tfarina2c773222016-04-05 18:43:35100
dpranke0ae7cad2016-11-30 07:47:58101### Run the hooks
tfarinaba2792fa2016-04-07 15:50:42102
dpranke0ae7cad2016-11-30 07:47:58103Once you've run `install-build-deps` at least once, you can now run the
sdy93387fa2016-12-01 01:03:44104Chromium-specific hooks, which will download additional binaries and other
dpranke0ae7cad2016-11-30 07:47:58105things you might need:
tfarinaba2792fa2016-04-07 15:50:42106
sdy93387fa2016-12-01 01:03:44107```shell
Andrew Grievec81af4a2017-07-26 18:02:13108gclient runhooks
sdy93387fa2016-12-01 01:03:44109```
tfarinaba2792fa2016-04-07 15:50:42110
sdy93387fa2016-12-01 01:03:44111*Optional*: You can also [install API
112keys](https://www.chromium.org/developers/how-tos/api-keys) if you want your
113build to talk to some Google services, but this is not necessary for most
114development and testing purposes.
tfarinaba2792fa2016-04-07 15:50:42115
dpranke1a70d0c2016-12-01 02:42:29116## Setting up the build
tfarinaba2792fa2016-04-07 15:50:42117
Tom Bridgwatereef401542018-08-17 00:54:43118Chromium uses [Ninja](https://ninja-build.org) as its main build tool along with
Andrew Williamsbbc1a1e2021-07-21 01:51:22119a tool called [GN](https://gn.googlesource.com/gn/+/main/docs/quick_start.md)
Tom Bridgwatereef401542018-08-17 00:54:43120to generate `.ninja` files. You can create any number of *build directories*
121with different configurations. To create a build directory which builds Chrome
Nate Fischerae5fd3222019-01-11 07:33:18122for Android, run `gn args out/Default` and edit the file to contain the
123following arguments:
tfarinaba2792fa2016-04-07 15:50:42124
Nate Fischerae5fd3222019-01-11 07:33:18125```gn
126target_os = "android"
127target_cpu = "arm64" # See "Figuring out target_cpu" below
sdy93387fa2016-12-01 01:03:44128```
dpranke0ae7cad2016-11-30 07:47:58129
Erik Chend73c50b2024-01-18 02:06:37130* There are several settings that will speed up compile/deploy time at the cost
131 of some unusual edge cases that will not affect most developers. See
132 `incremental_install` and other options below.
sdy93387fa2016-12-01 01:03:44133* You only have to run this once for each new build directory, Ninja will
134 update the build files as needed.
135* You can replace `Default` with another name, but
136 it should be a subdirectory of `out`.
137* For other build arguments, including release settings, see [GN build
138 configuration](https://www.chromium.org/developers/gn-build-configuration).
Nate Fischerae5fd3222019-01-11 07:33:18139 The default will be a debug component build.
dpranke0ae7cad2016-11-30 07:47:58140* For more info on GN, run `gn help` on the command line or read the
Andrew Williamsbbc1a1e2021-07-21 01:51:22141 [quick start guide](https://gn.googlesource.com/gn/+/main/docs/quick_start.md).
dpranke0ae7cad2016-11-30 07:47:58142
sdy93387fa2016-12-01 01:03:44143Also be aware that some scripts (e.g. `tombstones.py`, `adb_gdb.py`)
dpranke0ae7cad2016-11-30 07:47:58144require you to set `CHROMIUM_OUTPUT_DIR=out/Default`.
145
Nate Fischerae5fd3222019-01-11 07:33:18146### Figuring out target\_cpu
147
148The value of
Andrew Williamsbbc1a1e2021-07-21 01:51:22149[`target_cpu`](https://gn.googlesource.com/gn/+/main/docs/reference.md#var_target_cpu)
Nate Fischerae5fd3222019-01-11 07:33:18150determines what instruction set to use for native code. Given a device (or
151emulator), you can determine the correct instruction set with `adb shell getprop
152ro.product.cpu.abi`:
153
154| `getprop ro.product.cpu.abi` output | `target_cpu` value |
155|-------------------------------------|--------------------|
156| `arm64-v8a` | `arm64` |
157| `armeabi-v7a` | `arm` |
158| `x86` | `x86` |
159| `x86_64` | `x64` |
160
161*** promo
162`arm` and `x86` may optionally be used instead of `arm64` and `x64` for
163non-WebView targets. This is also allowed for Monochrome, but only when not set
Nate Fischer6402abdc2019-07-19 21:50:19164as the WebView provider.
Nate Fischerae5fd3222019-01-11 07:33:18165***
166
Andrew Williams54da9cc2024-01-09 17:32:23167### Faster builds
168
169This section contains some things you can change to speed up your builds,
170sorted so that the things that make the biggest difference are first.
171
172#### Use Reclient
173
174*** note
175**Warning:** If you are a Google employee, do not follow the instructions below.
176See
177[go/building-android-chrome#initialize-remote-execution-distributed-builds](https://goto.google.com/building-android-chrome#initialize-remote-execution-distributed-builds)
178instead.
179***
180
181Chromium's build can be sped up significantly by using a remote execution system
182compatible with [REAPI](https://github.com/bazelbuild/remote-apis). This allows
183you to benefit from remote caching and executing many build actions in parallel
184on a shared cluster of workers.
185
186To use Reclient, follow the corresponding
187[Linux build instructions](linux/build_instructions.md#use-reclient).
188
dpranke0ae7cad2016-11-30 07:47:58189## Build Chromium
190
191Build Chromium with Ninja using the command:
192
sdy93387fa2016-12-01 01:03:44193```shell
Max Morozf5b31fcd2018-08-10 21:55:48194autoninja -C out/Default chrome_public_apk
sdy93387fa2016-12-01 01:03:44195```
dpranke0ae7cad2016-11-30 07:47:58196
Dirk Pranke8bd55f22018-10-24 21:22:10197(`autoninja` is a wrapper that automatically provides optimal values for the
198arguments passed to `ninja`.)
Max Morozf5b31fcd2018-08-10 21:55:48199
sdy93387fa2016-12-01 01:03:44200You can get a list of all of the other build targets from GN by running `gn ls
201out/Default` from the command line. To compile one, pass the GN label to Ninja
Dirk Pranke8bd55f22018-10-24 21:22:10202with no preceding "//" (so, for `//chrome/test:unit_tests` use `autoninja -C
sdy93387fa2016-12-01 01:03:44203out/Default chrome/test:unit_tests`).
204
Peter Wenbe712e642019-11-14 21:36:58205### Multiple Chrome Targets
Andrew Grieve052376a2017-09-26 01:54:11206
Andrew Grieve90ba57f2023-05-10 19:07:40207The Google Play Store allows apps to send customized bundles (`.aab` files)
Peter Wenbe712e642019-11-14 21:36:58208depending on the version of Android running on a device. Chrome uses this
Andrew Grievef6069feb2021-04-29 18:29:17209feature to package optimized versions for different OS versions.
Andrew Grieve052376a2017-09-26 01:54:11210
Andrew Grieve90ba57f2023-05-10 19:07:402111. `monochrome_public_bundle` (`MonochromePublic.aab`)
Andrew Grieve4661a66c2022-12-09 14:09:47212 * `minSdkVersion=24` (Nougat).
Andrew Grievef6069feb2021-04-29 18:29:17213 * Contains both Chrome and WebView (to save disk space).
Andrew Grieve90ba57f2023-05-10 19:07:402142. `trichrome_chrome_bundle` (`TrichromeChrome.aab`)
Andrew Grievef6069feb2021-04-29 18:29:17215 * `minSdkVersion=29` (Android 10).
Erik Chend73c50b2024-01-18 02:06:37216 * Native code shared with WebView through a "Static Shared Library APK": `trichrome_library_apk`
Andrew Grievef6069feb2021-04-29 18:29:17217 * Corresponding WebView target: `trichrome_webview_bundle`
Andrew Grieve90ba57f2023-05-10 19:07:402183. `chrome_public_bundle` & `chrome_public_apk` (`ChromePublic.aab`, `ChromePublic.apk`)
Andrew Grieve9f504be2023-02-08 18:08:16219 * `minSdkVersion=24` (Nougat).
Andrew Grieve90ba57f2023-05-10 19:07:40220 * Used for local development (to avoid building WebView).
221 * WebView packaged independently (`system_webview_bundle` / `system_webview_apk`).
Andrew Grieve052376a2017-09-26 01:54:11222
Andrew Grievef6069feb2021-04-29 18:29:17223*** note
224**Notes:**
225* These instructions use `chrome_public_apk`, but any of the other targets can
226 be substituted.
227* For more about bundles, see [android_dynamic feature modules.md](android_dynamic_feature_modules.md).
228* For more about native library packaging & loading, see [android_native_libraries.md](android_native_libraries.md).
229* There are closed-source equivalents to these targets (for Googlers), which
230 are identical but link in some extra code.
231***
Andrew Grieved2ec82d2018-05-22 14:28:43232
Mark Pearsone9042242018-02-20 23:49:33233## Updating your checkout
234
235To update an existing checkout, you can run
236
237```shell
238$ git rebase-update
239$ gclient sync
240```
241
242The first command updates the primary Chromium source repository and rebases
243any of your local branches on top of tip-of-tree (aka the Git branch
Andrew Williamsbbc1a1e2021-07-21 01:51:22244`origin/main`). If you don't want to use this script, you can also just use
Mark Pearsone9042242018-02-20 23:49:33245`git pull` or other common Git commands to update the repo.
246
247The second command syncs dependencies to the appropriate versions and re-runs
248hooks as needed.
249
dpranke0ae7cad2016-11-30 07:47:58250## Installing and Running Chromium on a device
tfarinaba2792fa2016-04-07 15:50:42251
tfarinaba2792fa2016-04-07 15:50:42252### Plug in your Android device
253
254Make sure your Android device is plugged in via USB, and USB Debugging
255is enabled.
256
257To enable USB Debugging:
258
259* Navigate to Settings \> About Phone \> Build number
260* Click 'Build number' 7 times
261* Now navigate back to Settings \> Developer Options
262* Enable 'USB Debugging' and follow the prompts
263
264You may also be prompted to allow access to your PC once your device is
265plugged in.
266
267You can check if the device is connected by running:
268
269```shell
Yun Liuf57cceaf2019-03-18 21:31:23270third_party/android_sdk/public/platform-tools/adb devices
tfarinaba2792fa2016-04-07 15:50:42271```
272
273Which prints a list of connected devices. If not connected, try
274unplugging and reattaching your device.
tfarinaa68eb902016-04-12 19:43:05275
Thiemo Nagele03fb6c2018-07-31 08:29:31276### Enable apps from unknown sources
277
278Allow Android to run APKs that haven't been signed through the Play Store:
279
280* Enable 'Unknown sources' under Settings \> Security
281
282In case that setting isn't present, it may be possible to configure it via
283`adb shell` instead:
284
285```shell
Yun Liuf57cceaf2019-03-18 21:31:23286third_party/android_sdk/public/platform-tools/adb shell settings put global verifier_verify_adb_installs 0
Thiemo Nagele03fb6c2018-07-31 08:29:31287```
288
tfarinaa68eb902016-04-12 19:43:05289### Build the full browser
290
tfarinaa68eb902016-04-12 19:43:05291```shell
Max Morozf5b31fcd2018-08-10 21:55:48292autoninja -C out/Default chrome_public_apk
tfarinaa68eb902016-04-12 19:43:05293```
294
295And deploy it to your Android device:
296
297```shell
Andrew Grievec81af4a2017-07-26 18:02:13298out/Default/bin/chrome_public_apk install
tfarinaa68eb902016-04-12 19:43:05299```
300
301The app will appear on the device as "Chromium".
302
303### Build Content shell
304
305Wraps the content module (but not the /chrome embedder). See
xiaoyin.l1003c0b2016-12-06 02:51:17306[https://www.chromium.org/developers/content-module](https://www.chromium.org/developers/content-module)
tfarinaa68eb902016-04-12 19:43:05307for details on the content module and content shell.
308
309```shell
Max Morozf5b31fcd2018-08-10 21:55:48310autoninja -C out/Default content_shell_apk
Andrew Grievec81af4a2017-07-26 18:02:13311out/Default/bin/content_shell_apk install
tfarinaa68eb902016-04-12 19:43:05312```
313
314this will build and install an Android apk under
Yipeng Wang613ba692017-04-25 18:24:39315`out/Default/apks/ContentShell.apk`.
tfarinaa68eb902016-04-12 19:43:05316
ntfschr29a7adab2017-03-23 21:17:08317### Build WebView
tfarinaa68eb902016-04-12 19:43:05318
xiaoyin.l1003c0b2016-12-06 02:51:17319[Android WebView](https://developer.android.com/reference/android/webkit/WebView.html)
tfarinaa68eb902016-04-12 19:43:05320is a system framework component. Since Android KitKat, it is implemented using
xiaoyin.l1003c0b2016-12-06 02:51:17321Chromium code (based off the [content module](https://dev.chromium.org/developers/content-module)).
tfarinaa68eb902016-04-12 19:43:05322
ntfschr29a7adab2017-03-23 21:17:08323If you want to build the complete Android WebView framework component and test
324the effect of your chromium changes in Android apps using WebView, you should
325follow the [Android AOSP + chromium WebView
326instructions](https://www.chromium.org/developers/how-tos/build-instructions-android-webview)
tfarinaa68eb902016-04-12 19:43:05327
328### Running
329
tfarinaa68eb902016-04-12 19:43:05330For Content shell:
331
332```shell
Andrew Grievec81af4a2017-07-26 18:02:13333out/Default/bin/content_shell_apk launch [--args='--foo --bar'] http://example.com
tfarinaa68eb902016-04-12 19:43:05334```
335
336For Chrome public:
337
338```shell
Andrew Grievec81af4a2017-07-26 18:02:13339out/Default/bin/chrome_public_apk launch [--args='--foo --bar'] http://example.com
tfarinaa68eb902016-04-12 19:43:05340```
341
tfarinaa68eb902016-04-12 19:43:05342### Logging and debugging
343
344Logging is often the easiest way to understand code flow. In C++ you can print
Andrew Grievec81af4a2017-07-26 18:02:13345log statements using the LOG macro. In Java, refer to
346[android_logging.md](android_logging.md).
tfarinaa68eb902016-04-12 19:43:05347
Andrew Grievec81af4a2017-07-26 18:02:13348You can see these log via `adb logcat`, or:
tfarinaa68eb902016-04-12 19:43:05349
350```shell
Andrew Grievec81af4a2017-07-26 18:02:13351out/Default/bin/chrome_public_apk logcat
tfarinaa68eb902016-04-12 19:43:05352```
353
Tomasz Wiszkowski6467f1c92021-04-08 21:54:42354Logcat supports an additional feature of filtering and highlighting user-defined patterns. To use
355this mechanism, define a shell variable: `CHROMIUM_LOGCAT_HIGHLIGHT` and assign your desired
356pattern. The pattern will be used to search for any substring (ie. no need to prefix or suffix it
357with `.*`), eg:
358
359```shell
360export CHROMIUM_LOGCAT_HIGHLIGHT='(WARNING|cr_Child)'
박중헌e605cf2a2023-08-22 05:17:42361out/Default/bin/chrome_public_apk logcat
Tomasz Wiszkowski6467f1c92021-04-08 21:54:42362# Highlights messages/tags containing WARNING and cr_Child strings.
363```
364
365Note: both _Message_ and _Tag_ portion of logcat are matched against the pattern.
366
Andrew Grievec81af4a2017-07-26 18:02:13367To debug C++ code, use one of the following commands:
tfarinaa68eb902016-04-12 19:43:05368
369```shell
Andrew Grievec81af4a2017-07-26 18:02:13370out/Default/bin/content_shell_apk gdb
371out/Default/bin/chrome_public_apk gdb
tfarinaa68eb902016-04-12 19:43:05372```
373
Philip Jägenstedt17f89962017-05-18 08:25:54374See [Android Debugging Instructions](android_debugging_instructions.md)
tfarinaa68eb902016-04-12 19:43:05375for more on debugging, including how to debug Java code.
376
377### Testing
378
Ken Rockot35028ca2019-05-30 18:50:45379For information on running tests, see
Andrew Grieveb5b3bb32023-10-04 13:55:51380[Android Test Instructions](/docs/testing/android_test_instructions.md)
tfarinaa68eb902016-04-12 19:43:05381
Andrew Grievec81af4a2017-07-26 18:02:13382### Faster Edit/Deploy
tfarinaa68eb902016-04-12 19:43:05383
agrieveb0861f522018-10-17 19:48:36384#### GN Args
385Args that affect build speed:
386 * `is_component_build = true` *(default=`is_debug`)*
387 * What it does: Uses multiple `.so` files instead of just one (faster links)
388 * `is_java_debug = true` *(default=`is_debug`)*
389 * What it does: Disables ProGuard (slow build step)
Andrew Grieve4978e8d2020-07-21 14:29:56390 * `treat_warnings_as_errors = false` *(default=`true`)*
391 * Causes any compiler warnings or lint checks to not fail the build.
392 * Allows you to iterate without needing to satisfy static analysis checks.
Peter Wen9e3ef452022-02-02 16:48:57393 * `android_static_analysis = "build_server"` *(default=`"on"`)*
394 * Offloads static analysis steps to the build server. Explained below.
395 * Set this to `"off"` if you want to turn off static analysis altogether.
396 * `incremental_install = true` *(default=`false`)*
397 * Makes build and install quite a bit faster. Explained in a later section.
agrieveb0861f522018-10-17 19:48:36398
Peter Wen9e3ef452022-02-02 16:48:57399#### Running static analysis with the build server
Peter Wenc4bf57622021-04-12 22:12:36400Normally analysis build steps like lint and errorprone will run in parallel with
401the rest of the build. The build will then wait for all analysis steps to
402complete successfully. By offloading analysis build steps to a separate build
403server to be run lazily at a low priority when the machine is idle, the actual
404build can complete up to 50-80% faster.
405
Peter Wen38be2fbc2023-02-09 19:04:10406**Note**: Since the build completes before the analysis checks finish, the build
407will not fail if an analysis check fails. Make sure to check the server's output
408at regular intervals to fix outstanding issues caught by these analysis checks.
409
410##### First way (by running it manually)
411
Victor Hugo Vianna Silva3d39c7f2022-03-21 10:15:27412There are **two** steps to using the build server.
4131. Add the gn arg `android_static_analysis = "build_server"`
4142. Run the script at
415[//build/android/fast_local_dev_server.py][fast_local_dev]
Peter Wen9e3ef452022-02-02 16:48:57416
Victor Hugo Vianna Silva3d39c7f2022-03-21 10:15:27417All your local builds will now forward analysis steps to this server, including
418android lint, errorprone, bytecode processor.
419
420If you run (2) in a terminal, the output of the checks will be displayed there.
Peter Wen38be2fbc2023-02-09 19:04:10421
422##### Second way (using systemd)
423
Victor Hugo Vianna Silva3d39c7f2022-03-21 10:15:27424Alternatively, you can set up the server as a Linux service, so it runs on the
425background and starts on boot. If you're using systemd:
426
Victor Hugo Vianna Silvab137ef4e2022-04-06 17:30:18427Save the following as /etc/systemd/user/fast-local-dev-server.service.
Victor Hugo Vianna Silva3d39c7f2022-03-21 10:15:27428```
429[Unit]
430Description=Chrome server for android build static analysis
431
432[Service]
433Type=simple
434ExecStart=<path to fast_local_dev_server.py>
435Restart=always
436
437[Install]
Victor Hugo Vianna Silvab137ef4e2022-04-06 17:30:18438WantedBy=default.target
Peter Wen9e3ef452022-02-02 16:48:57439```
440
Victor Hugo Vianna Silva3d39c7f2022-03-21 10:15:27441Then
442```bash
Victor Hugo Vianna Silvab137ef4e2022-04-06 17:30:18443systemctl --user daemon-reload
444systemctl --user enable fast-local-dev-server
445systemctl --user start fast-local-dev-server
Victor Hugo Vianna Silva3d39c7f2022-03-21 10:15:27446```
Peter Wen9e3ef452022-02-02 16:48:57447
Victor Hugo Vianna Silva3d39c7f2022-03-21 10:15:27448The output can be inspected with
449```
Victor Hugo Vianna Silvab137ef4e2022-04-06 17:30:18450journalctl --user -e -u fast-local-dev-server
Victor Hugo Vianna Silva3d39c7f2022-03-21 10:15:27451```
Peter Wenc4bf57622021-04-12 22:12:36452
John Palmer046f9872021-05-24 01:24:56453[fast_local_dev]: https://source.chromium.org/chromium/chromium/src/+/main:build/android/fast_local_dev_server.py
Peter Wenc4bf57622021-04-12 22:12:36454
agrieveb0861f522018-10-17 19:48:36455#### Incremental Install
Andrew Grievee1dc23f2019-10-22 16:26:36456[Incremental Install](/build/android/incremental_install/README.md) uses
Andrew Grievec45749e52019-10-22 20:59:56457reflection and sideloading to speed up the edit & deploy cycle (normally < 10
Andrew Grievee1dc23f2019-10-22 16:26:36458seconds). The initial launch of the apk will be a lot slower on older Android
459versions (pre-N) where the OS needs to pre-optimize the side-loaded files, but
460then be only marginally slower after the first launch.
tfarinaa68eb902016-04-12 19:43:05461
Andrew Grievee1dc23f2019-10-22 16:26:36462To enable Incremental Install, add the gn args:
tfarinaa68eb902016-04-12 19:43:05463
Andrew Grievee1dc23f2019-10-22 16:26:36464```gn
465incremental_install = true
tfarinaa68eb902016-04-12 19:43:05466```
467
Daniel Cheng243aad32022-02-26 03:33:14468Some APKs (e.g. WebView) do not work with `incremental install = true` and are
469always built as normal APKs. This behavior is controlled via
470`never_incremental = true`.
tfarinaa68eb902016-04-12 19:43:05471
Andrew Grieveae094e392018-06-15 16:10:22472## Installing and Running Chromium on an Emulator
473
474Running on an emulator is the same as on a device. Refer to
Raphael Kubo da Costafe411ff2018-06-20 08:16:50475[android_emulator.md](android_emulator.md) for setting up emulators.
Andrew Grieveae094e392018-06-15 16:10:22476
dpranke0ae7cad2016-11-30 07:47:58477## Tips, tricks, and troubleshooting
tfarinaa68eb902016-04-12 19:43:05478
dpranke0ae7cad2016-11-30 07:47:58479### Rebuilding libchrome.so for a particular release
tfarinaa68eb902016-04-12 19:43:05480
yfriedman9b4327b2016-05-04 16:36:24481These instructions are only necessary for Chrome 51 and earlier.
482
tfarinaa68eb902016-04-12 19:43:05483In the case where you want to modify the native code for an existing
484release of Chrome for Android (v25+) you can do the following steps.
485Note that in order to get your changes into the official release, you'll
486need to send your change for a codereview using the regular process for
487committing code to chromium.
488
4891. Open Chrome on your Android device and visit chrome://version
4902. Copy down the id listed next to "Build ID:"
4913. Go to
492 [http://storage.googleapis.com/chrome-browser-components/BUILD\_ID\_FROM\_STEP\_2/index.html](http://storage.googleapis.com/chrome-browser-components/BUILD_ID_FROM_STEP_2/index.html)
4934. Download the listed files and follow the steps in the README.