jbudorick | 900a8d83 | 2016-07-18 18:56:05 | [diff] [blame] | 1 | # Android Studio |
| 2 | |
jbudorick | 900a8d83 | 2016-07-18 18:56:05 | [diff] [blame] | 3 | [TOC] |
| 4 | |
| 5 | ## Usage |
| 6 | |
wnwen | 9032b35 | 2017-02-09 15:53:33 | [diff] [blame] | 7 | Make sure you have followed |
| 8 | [android build instructions](android_build_instructions.md) already. |
wnwen | e397fec6 | 2017-01-19 20:25:21 | [diff] [blame] | 9 | |
jbudorick | 900a8d83 | 2016-07-18 18:56:05 | [diff] [blame] | 10 | ```shell |
wnwen | e397fec6 | 2017-01-19 20:25:21 | [diff] [blame] | 11 | build/android/gradle/generate_gradle.py |
jbudorick | 900a8d83 | 2016-07-18 18:56:05 | [diff] [blame] | 12 | ``` |
| 13 | |
wnwen | e397fec6 | 2017-01-19 20:25:21 | [diff] [blame] | 14 | This creates a project at `out/Debug/gradle`. To create elsewhere: |
agrieve | e244c1a | 2016-09-22 19:35:18 | [diff] [blame] | 15 | |
| 16 | ```shell |
wnwen | e397fec6 | 2017-01-19 20:25:21 | [diff] [blame] | 17 | build/android/gradle/generate_gradle.py --output-directory out/My-Out-Dir --project-dir my-project |
agrieve | e244c1a | 2016-09-22 19:35:18 | [diff] [blame] | 18 | ``` |
| 19 | |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 20 | By default, common targets are generated. To add more targets to generate |
| 21 | projects for: |
agrieve | e244c1a | 2016-09-22 19:35:18 | [diff] [blame] | 22 | |
| 23 | ```shell |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 24 | build/android/gradle/generate_gradle.py --extra-target //chrome/android:chrome_public_apk |
agrieve | e244c1a | 2016-09-22 19:35:18 | [diff] [blame] | 25 | ``` |
jbudorick | 900a8d83 | 2016-07-18 18:56:05 | [diff] [blame] | 26 | |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 27 | For first-time Android Studio users: |
| 28 | |
wnwen | d65703a | 2016-11-24 18:47:31 | [diff] [blame] | 29 | * Avoid running the setup wizard. |
wnwen | 9032b35 | 2017-02-09 15:53:33 | [diff] [blame] | 30 | * The wizard will force you to download unwanted SDK components to |
| 31 | `//third_party/android_tools`. |
agrieve | c62a52d | 2016-09-22 01:48:24 | [diff] [blame] | 32 | * To skip it, select "Cancel" when it comes up. |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 33 | |
wnwen | e851ad47 | 2017-04-27 16:21:42 | [diff] [blame] | 34 | For those upgrading from Android Studio 2.2 to 2.3: |
| 35 | |
| 36 | * Use `gn clean` and `gn gen` |
| 37 | * Clean up in `//third_party/android_tools` with `git clean -ffd`. |
| 38 | * Remove project from android studio and regenerate with `generate_gradle.py`. |
| 39 | |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 40 | To import the project: |
| 41 | |
wnwen | 9032b35 | 2017-02-09 15:53:33 | [diff] [blame] | 42 | * Use "Import Project", and select the directory containing the generated |
wnwen | 0227e4a5 | 2017-02-09 21:14:51 | [diff] [blame] | 43 | project, by default `out/Debug/gradle`. |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 44 | |
| 45 | You need to re-run `generate_gradle.py` whenever `BUILD.gn` files change. |
| 46 | |
wnwen | 9032b35 | 2017-02-09 15:53:33 | [diff] [blame] | 47 | * After regenerating, Android Studio should prompt you to "Sync". If it |
| 48 | doesn't, use: |
wnwen | 0227e4a5 | 2017-02-09 21:14:51 | [diff] [blame] | 49 | * Button with two arrows on the right side of the top strip. |
wnwen | d65703a | 2016-11-24 18:47:31 | [diff] [blame] | 50 | * Help -> Find Action -> "Sync Project with Gradle Files" |
wnwen | 0227e4a5 | 2017-02-09 21:14:51 | [diff] [blame] | 51 | * After `gn clean` you may need to restart Android Studio. |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 52 | |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 53 | ## How It Works |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 54 | |
wnwen | e851ad47 | 2017-04-27 16:21:42 | [diff] [blame] | 55 | By default, only a single module is generated. If more than one apk target is |
| 56 | specified, then an `_all` module is generated. Otherwise a single apk module is |
| 57 | generated. Since instrumentation tests are combined with their `apk_under_test` |
| 58 | target, they count as one module together. |
| 59 | |
| 60 | To see more detailed structure of gn targets, the `--split-projects` flag can |
| 61 | be used. This will generate one module for every gn target in the dependency |
| 62 | graph. |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 63 | |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 64 | ### Excluded Files |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 65 | |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 66 | Gradle supports source directories but not source files. However, files in |
| 67 | Chromium are used amongst multiple targets. To accommodate this, the script |
| 68 | detects such targets and creates exclude patterns to exclude files not in the |
| 69 | current target. The editor does not respect these exclude patterns, so a `_all` |
| 70 | pseudo module is added which includes directories from all targets. This allows |
| 71 | imports and refactorings to be searched across all targets. |
| 72 | |
| 73 | ### Extracting .srcjars |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 74 | |
| 75 | Most generated .java files in GN are stored as `.srcjars`. Android Studio does |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 76 | not support them, and so the generator script builds and extracts them all to |
| 77 | `extracted-srcjars/` subdirectories for each target that contains them. This is |
| 78 | the reason that the `_all` pseudo module may contain multiple copies of |
| 79 | generated files. |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 80 | |
| 81 | *** note |
| 82 | ** TLDR:** Always re-generate project files when `.srcjars` change (this |
| 83 | includes `R.java`). |
| 84 | *** |
| 85 | |
jbudorick | 900a8d83 | 2016-07-18 18:56:05 | [diff] [blame] | 86 | ## Android Studio Tips |
| 87 | |
wnwen | 9032b35 | 2017-02-09 15:53:33 | [diff] [blame] | 88 | * Configuration instructions can be found |
| 89 | [here](http://tools.android.com/tech-docs/configuration). One suggestions: |
| 90 | * Launch it with more RAM: |
| 91 | `STUDIO_VM_OPTIONS=-Xmx2048m /opt/android-studio-stable/bin/studio-launcher.sh` |
wnwen | d65703a | 2016-11-24 18:47:31 | [diff] [blame] | 92 | * If you ever need to reset it: `rm -r ~/.AndroidStudio*/` |
| 93 | * Import Android style settings: |
wnwen | 9032b35 | 2017-02-09 15:53:33 | [diff] [blame] | 94 | * Help -> Find Action -> "Code Style" (settings) -> Java -> |
estevenson | 2ecfaf6 | 2017-05-04 18:33:04 | [diff] [blame] | 95 | Manage -> Import -> select "Intellij IDEA code style XML" -> OK |
nyquist | 6e560d03 | 2017-02-28 07:49:59 | [diff] [blame] | 96 | * Select `tools/android/android_studio/ChromiumStyle.xml` |
wnwen | d65703a | 2016-11-24 18:47:31 | [diff] [blame] | 97 | * Turn on automatic import: |
| 98 | * Help -> Find Action -> "Auto Import" |
| 99 | * Tick all the boxes under "Java" and change the dropdown to "All". |
wnwen | 67b6497 | 2016-12-19 19:53:15 | [diff] [blame] | 100 | * Turn on documentation on mouse hover: |
| 101 | * Help -> Find Action -> "Show quick documentation on mouse move" |
| 102 | * Turn on line numbers: |
| 103 | * Help -> Find Action -> "Show line numbers" |
zpeng | 38bf00de | 2017-05-10 16:05:03 | [diff] [blame^] | 104 | * Format changed files (Useful for changes made by running code inspection): |
| 105 | * Set up version control |
| 106 | * File -> Settings -> Version Control |
| 107 | * Add src directories |
| 108 | * Commit changes and reformat |
| 109 | * Help -> Find Action -> "Commit Changes" |
| 110 | * Check "Reformat code" & "Optimize imports" and commit |
agrieve | 0c28e4f | 2016-09-22 01:05:20 | [diff] [blame] | 111 | |
| 112 | ### Useful Shortcuts |
| 113 | |
wnwen | d65703a | 2016-11-24 18:47:31 | [diff] [blame] | 114 | * `Shift - Shift`: Search to open file or perform IDE action |
| 115 | * `Ctrl + N`: Jump to class |
| 116 | * `Ctrl + Shift + T`: Jump to test |
| 117 | * `Ctrl + Shift + N`: Jump to file |
| 118 | * `Ctrl + F12`: Jump to method |
| 119 | * `Ctrl + G`: Jump to line |
| 120 | * `Shift + F6`: Rename variable |
| 121 | * `Ctrl + Alt + O`: Organize imports |
| 122 | * `Alt + Enter`: Quick Fix (use on underlined errors) |
wnwen | fdea62ce | 2017-04-05 13:12:54 | [diff] [blame] | 123 | * `F2`: Find next error |
jbudorick | 900a8d83 | 2016-07-18 18:56:05 | [diff] [blame] | 124 | |
agrieve | c62a52d | 2016-09-22 01:48:24 | [diff] [blame] | 125 | ### Building from the Command Line |
| 126 | |
wnwen | 9032b35 | 2017-02-09 15:53:33 | [diff] [blame] | 127 | Gradle builds can be done from the command-line after importing the project |
| 128 | into Android Studio (importing into the IDE causes the Gradle wrapper to be |
| 129 | added). This wrapper can also be used to invoke gradle commands. |
agrieve | c62a52d | 2016-09-22 01:48:24 | [diff] [blame] | 130 | |
| 131 | cd $GRADLE_PROJECT_DIR && bash gradlew |
| 132 | |
| 133 | The resulting artifacts are not terribly useful. They are missing assets, |
| 134 | resources, native libraries, etc. |
| 135 | |
wnwen | 9032b35 | 2017-02-09 15:53:33 | [diff] [blame] | 136 | * Use a |
| 137 | [gradle daemon](https://docs.gradle.org/2.14.1/userguide/gradle_daemon.html) |
| 138 | to speed up builds using the gradlew script: |
| 139 | * Add the line `org.gradle.daemon=true` to `~/.gradle/gradle.properties`, |
| 140 | creating it if necessary. |
wnwen | 660b131 | 2016-10-21 16:46:22 | [diff] [blame] | 141 | |
wnwen | e851ad47 | 2017-04-27 16:21:42 | [diff] [blame] | 142 | ## Status (as of April 27th, 2017) |
agrieve | c62a52d | 2016-09-22 01:48:24 | [diff] [blame] | 143 | |
| 144 | ### What works |
| 145 | |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 146 | * Android Studio v2.3. |
| 147 | * Java editing and gradle compile. |
wnwen | e397fec6 | 2017-01-19 20:25:21 | [diff] [blame] | 148 | * Instrumentation tests included as androidTest. |
| 149 | * Symlinks to existing .so files in jniLibs (doesn't generate them). |
wnwen | 0227e4a5 | 2017-02-09 21:14:51 | [diff] [blame] | 150 | * Editing resource xml files. |
estevenson | 8c9318ff | 2017-03-10 22:16:35 | [diff] [blame] | 151 | * Java debugging (see |
wnwen | fdea62ce | 2017-04-05 13:12:54 | [diff] [blame] | 152 | [here](/docs/android_debugging_instructions.md#Android-Studio)). |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 153 | * Import resolution and refactoring across all modules. |
wnwen | e851ad47 | 2017-04-27 16:21:42 | [diff] [blame] | 154 | * Correct lint and AndroidManifest when only one target is specified. |
agrieve | c62a52d | 2016-09-22 01:48:24 | [diff] [blame] | 155 | |
| 156 | ### What doesn't work (yet) ([crbug](https://bugs.chromium.org/p/chromium/issues/detail?id=620034)) |
| 157 | |
wnwen | 03427bc | 2017-04-19 19:22:24 | [diff] [blame] | 158 | * Gradle being aware of assets. |
wnwen | fdea62ce | 2017-04-05 13:12:54 | [diff] [blame] | 159 | * Layout editor. |
wnwen | fdea62ce | 2017-04-05 13:12:54 | [diff] [blame] | 160 | * Add support for native code editing. |
| 161 | * Make the "Make Project" button work correctly. |