nodir | 469b2a1 | 2015-09-14 16:20:21 | [diff] [blame] | 1 | # Chromium docs |
| 2 | |
pwnall | 3f91838 | 2016-11-16 17:22:12 | [diff] [blame] | 3 | This directory contains chromium project documentation in |
Vincent Scheib | de853a0 | 2017-07-13 23:31:18 | [diff] [blame] | 4 | [Gitiles-flavored Markdown]. It is automatically [rendered by Gitiles]. |
| 5 | |
| 6 | [Gitiles-flavored Markdown]: https://gerrit.googlesource.com/gitiles/+/master/Documentation/markdown.md |
| 7 | [rendered by Gitiles]: https://chromium.googlesource.com/chromium/src/+/master/docs/ |
nodir | 469b2a1 | 2015-09-14 16:20:21 | [diff] [blame] | 8 | |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 9 | If you add new documents, please also add a link to them in the Document Index |
| 10 | below. |
| 11 | |
| 12 | [TOC] |
| 13 | |
Vincent Scheib | 394b907a | 2017-07-14 22:30:06 | [diff] [blame] | 14 | ## Creating Documentation |
nodir | 469b2a1 | 2015-09-14 16:20:21 | [diff] [blame] | 15 | |
Vincent Scheib | de853a0 | 2017-07-13 23:31:18 | [diff] [blame] | 16 | Markdown documents must follow the |
| 17 | [style guide](https://github.com/google/styleguide/tree/gh-pages/docguide). |
nodir | 469b2a1 | 2015-09-14 16:20:21 | [diff] [blame] | 18 | |
Vincent Scheib | 394b907a | 2017-07-14 22:30:06 | [diff] [blame] | 19 | ### Preview local changes using [md_browser](../tools/md_browser/): |
nodir | 6efa499 | 2015-12-20 00:54:33 | [diff] [blame] | 20 | |
| 21 | ```bash |
| 22 | # in chromium checkout |
agable | d40b954 | 2016-05-11 01:15:06 | [diff] [blame] | 23 | ./tools/md_browser/md_browser.py |
nodir | 6efa499 | 2015-12-20 00:54:33 | [diff] [blame] | 24 | ``` |
| 25 | |
Vincent Scheib | 394b907a | 2017-07-14 22:30:06 | [diff] [blame] | 26 | This is only an estimate. The **gitiles** view may differ. |
nodir | 6efa499 | 2015-12-20 00:54:33 | [diff] [blame] | 27 | |
Vincent Scheib | 394b907a | 2017-07-14 22:30:06 | [diff] [blame] | 28 | ### Review changes online with gerrit's links to gitiles: |
| 29 | |
Mathieu Perreault | 33962538 | 2017-07-29 00:32:58 | [diff] [blame] | 30 | 1. Upload a patch to gerrit, or receive a review request. |
Vincent Scheib | 394b907a | 2017-07-14 22:30:06 | [diff] [blame] | 31 | e.g. https://chromium-review.googlesource.com/c/572236 |
Mathieu Perreault | 33962538 | 2017-07-29 00:32:58 | [diff] [blame] | 32 | 2. View a specific .md file. |
Vincent Scheib | 394b907a | 2017-07-14 22:30:06 | [diff] [blame] | 33 | e.g. https://chromium-review.googlesource.com/c/572236/2/docs/README.md |
| 34 | 3. Click on **gitiles** link at top of page. |
| 35 | |
| 36 | This **gitiles** view is the authoritative view, exactly the same as will be |
| 37 | used when committed. |
nodir | 6efa499 | 2015-12-20 00:54:33 | [diff] [blame] | 38 | |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 39 | ## Document Index |
| 40 | |
| 41 | ### Checking Out and Building |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 42 | * [Linux Build Instructions](linux/build_instructions.md) - Linux |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 43 | * [Mac Build Instructions](mac_build_instructions.md) - MacOS |
| 44 | * [Windows Build Instructions](windows_build_instructions.md) - Windows |
| 45 | * [Android Build Instructions](android_build_instructions.md) - Android target |
| 46 | (on a Linux host) |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 47 | * [Cast Build Instructions](linux/cast_build_instructions.md) - Cast target |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 48 | (on a Linux host) |
| 49 | * [Cast for Android Build Instructions](android_cast_build_instructions.md) - |
| 50 | Cast for Android (on a Linux host) |
Scott Graham | 6b17c652 | 2018-09-25 20:39:36 | [diff] [blame] | 51 | * [Fuchsia Build Instructions](fuchsia_build_instructions.md) - Fuchsia target |
| 52 | (on a Linux host) |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 53 | * [iOS Build Instructions](ios/build_instructions.md) - iOS target (on a MacOS |
| 54 | host) |
Euisang Lim | 1f25391 | 2018-04-30 01:46:32 | [diff] [blame] | 55 | * [Chrome OS Build Instructions](chromeos_build_instructions.md) - Chrome OS |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 56 | * [Linux Chromium ARM Recipes](linux/chromium_arm.md) - Recipes for building |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 57 | Chromium for ARM on Linux. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 58 | * [Chrome Component Build](component_build.md) - Faster builds using more |
| 59 | libraries |
| 60 | * [Using the BuildRunner](using_build_runner.md) - Scripts that extract build |
| 61 | stops from builders and runs them locally on a slave |
| 62 | * [Cr User Manual](cr_user_manual.md) - Manual for `cr`, a tool that tries to |
| 63 | hide some of the tools used for working on Chromium behind an abstraction |
| 64 | layer |
| 65 | |
justincarlson | ad589ce | 2017-04-20 17:26:07 | [diff] [blame] | 66 | ### Design Docs |
| 67 | * See [design/README.md](design/README.md) |
| 68 | |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 69 | ### Integrated Development Environment (IDE) Set Up Guides |
| 70 | * [Android Studio](android_studio.md) - Android Studio for Android builds |
manukh | 080b47e | 2019-12-19 22:06:19 | [diff] [blame] | 71 | * [Atom](atom.md) - Atom multi-platform code editor |
| 72 | * [CLion](clion.md) - CLion IDE, supports GUI debugging. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 73 | * [Eclipse for Android](eclipse.md) - Eclipse for Android |
Vincent Scheib | 196c7b4 | 2019-12-21 00:29:19 | [diff] [blame] | 74 | * [Eclipse for Linux](linux/eclipse_dev.md) - Eclipse for other platforms |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 75 | (This guide was written for Linux, but is probably usable on Windows/MacOS |
| 76 | as well) |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 77 | * [EMACS Notes](emacs.md) - EMACS commands/styles/tool integrations |
manukh | 080b47e | 2019-12-19 22:06:19 | [diff] [blame] | 78 | * [Qt Creator](qtcreator.md) - Using Qt Creator as an IDE or GUI debugger |
| 79 | * [Visual Studio Code](vscode.md) - Visual Studio Code |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 80 | |
| 81 | ### Git |
| 82 | * [Git Cookbook](git_cookbook.md) - A collection of git recipes for common |
| 83 | tasks |
| 84 | * [Git Tips](git_tips.md) - More git tips |
| 85 | |
| 86 | ### Clang |
| 87 | * [Clang Compiler](clang.md) - General information on the clang compiler, used |
| 88 | by default on Mac and Linux |
| 89 | * [Clang Tool Refactoring](clang_tool_refactoring.md) - Leveraging clang tools |
| 90 | to perform refactorings that are AST-aware |
| 91 | * [The Clang Static Analyzer](clang_static_analyzer.md) - How to enable static |
| 92 | analysis at build time |
Yuke Liao | bb571bd6 | 2018-10-31 21:51:52 | [diff] [blame] | 93 | * [Clang Code Coverage Wrapper](clang_code_coverage_wrapper.md) - Enable Clang |
| 94 | code coverage instrumentation for a subset of source files. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 95 | * [Writing Clang Plugins](writing_clang_plugins.md) - Don't write a clang |
| 96 | plugin, but if you do, read this |
| 97 | * [Updating Clang](updating_clang.md) - Updating the version of Clang used to |
| 98 | build |
| 99 | * [Using clang-format on Chromium C++ Code](clang_format.md) - Various ways to |
| 100 | invoke clang-format on C++ code |
| 101 | * [Clang Tidy](clang_tidy.md) - Support for the `clang-tidy` tool in Chromium |
| 102 | * [Updating Clang Format Binaries](updating_clang_format_binaries.md) - How up |
| 103 | update the clang-format binaries that come with a checkout of Chromium |
| 104 | |
| 105 | ### General Development |
Toby Huang | 5105f81 | 2019-08-08 23:47:57 | [diff] [blame] | 106 | * [Contributing to Chromium](contributing.md) - Reference workflow process for |
| 107 | contributing to the Chromium code base. |
| 108 | * [Commit Checklist](commit_checklist.md) - Streamlined checklist to go |
| 109 | through before uploading CLs on Gerrit. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 110 | * [Code Reviews](code_reviews.md) - Code review requirements and guidelines |
Mathieu Perreault | 33962538 | 2017-07-29 00:32:58 | [diff] [blame] | 111 | * [Respectful Code Reviews](cr_respect.md) - A guide for code reviewers |
| 112 | * [Respectful Changes](cl_respect.md) - A guide for code authors |
Yulan Lin | 55ae6a3 | 2020-07-31 17:58:29 | [diff] [blame] | 113 | * [Mandatory Code-Review Rollout](code_review_owners.md) - Upcoming policy changes related to code review and OWNERS |
Eric Foo | 6ea4fbd | 2018-01-17 04:04:50 | [diff] [blame] | 114 | * [LUCI Migration FAQ](luci_migration_faq.md) - FAQ on Buildbot-to-LUCI |
| 115 | builder migration for Chromium |
Eric Foo | ff7b498 | 2017-12-19 01:59:15 | [diff] [blame] | 116 | * [Tour of Continuous Integration UI](tour_of_luci_ui.md) - A tour of our |
Eric Foo | 6ea4fbd | 2018-01-17 04:04:50 | [diff] [blame] | 117 | the user interface for LUCI, our continuous integration system |
erikchen | b83e010a | 2018-10-08 21:34:01 | [diff] [blame] | 118 | * [Parsing Test Results](parsing_test_results.md) - An introduction for how to |
| 119 | understand the results emitted by polygerrit and CI builds. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 120 | * [Closure Compilation](closure_compilation.md) - The _Closure_ JavaScript |
| 121 | compiler |
fdoray | bacba4a2 | 2017-05-10 21:10:00 | [diff] [blame] | 122 | * [Threading and Tasks in Chrome](threading_and_tasks.md) - How to run tasks |
| 123 | and handle thread safety in Chrome. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 124 | * [Callback<> and Bind()](callback.md) - All about Callbacks, Closures, and |
| 125 | Bind(). |
| 126 | * [Views Platform Styling](ui/views/platform_style.md) - How views are styled |
| 127 | to fit in different native platforms |
| 128 | * [Tab Helpers](tab_helpers.md) - Using WebContents/WebContentsObserver to add |
| 129 | features to browser tabs. |
| 130 | * [Adding third_party Libraries](adding_to_third_party.md) - How to get code |
| 131 | into third_party/ |
| 132 | * [Graphical Debugging Aid for Chromium Views](graphical_debugging_aid_chromium_views.md) - |
| 133 | Visualizing view trees during debugging |
| 134 | * [Bitmap Pipeline](bitmap_pipeline.md) - How bitmaps are moved from the |
| 135 | renderer to the screen. |
| 136 | * [base::Optional](optional.md) - How to use `base::Optional` in C++ code. |
| 137 | * [Using the Origin Trials Framework](origin_trials_integration.md) - A |
| 138 | framework for conditionally enabling experimental APIs for testing. |
Jan Krcal | 02520366d | 2018-03-07 10:05:18 | [diff] [blame] | 139 | * [`ClientTagBasedModelTypeProcessor` in Unified Sync and Storage](sync/uss/client_tag_based_model_type_processor.md) - |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 140 | Notes on the central data structure used in Chrome Sync. |
| 141 | * [Chrome Sync's Model API](sync/model_api.md) - Data models used for syncing |
| 142 | information across devices using Chrome Sync. |
| 143 | * [Ozone Overview](ozone_overview.md) - Ozone is an abstraction layer between |
| 144 | the window system and low level input and graphics. |
| 145 | * [Optimizing Chrome Web UIs](optimizing_web_uis.md) - Notes on making webuis |
| 146 | more performant |
Makoto Shimazu | 9f0bd3a | 2017-08-08 01:54:24 | [diff] [blame] | 147 | * [Adding a new feature flag in chrome://flags](how_to_add_your_feature_flag.md) - Quick |
| 148 | guide to add a new feature flag to experiment your feature. |
Dimitri Glazkov | 2070775d | 2017-10-24 17:47:02 | [diff] [blame] | 149 | * [Guidelines for considering branch dates in project planning](release_branch_guidance.md) - |
| 150 | What to do (and not to do) around branch dates when scheduling your project |
| 151 | work. |
Dan Beam | 1981221 | 2018-11-29 08:16:56 | [diff] [blame] | 152 | * [WebUI Explainer](webui_explainer.md) - An explanation of C++ and JavaScript |
| 153 | infrastructural code for Chrome UIs implemented with web technologies (i.e. |
| 154 | chrome:// URLs). |
Dominik Röttsches | d113bfa | 2019-07-10 08:56:24 | [diff] [blame] | 155 | * [Watchlists](infra/watchlists.md) - Use watchlists to get notified of CLs |
| 156 | you are interested in. |
Francois Doray | 7c0e5443 | 2020-08-25 15:27:28 | [diff] [blame] | 157 | * [Shutdown](shutdown.md) - Explains the steps of Chrome shutdown, to make it |
| 158 | easier to determine where to add a new shutdown operation. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 159 | |
| 160 | ### Testing |
Kent Tamura | 59ffb02 | 2018-11-27 05:30:56 | [diff] [blame] | 161 | * [Running and Debugging Web Tests](testing/web_tests.md) |
Dirk Pranke | 78557c5 | 2020-09-26 19:04:09 | [diff] [blame] | 162 | * [On disabling tests](testing/disabling_tests.md) |
Kent Tamura | 59ffb02 | 2018-11-27 05:30:56 | [diff] [blame] | 163 | * [Writing Web Tests](testing/writing_web_tests.md) - Web Tests using |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 164 | `content_shell` |
Kent Tamura | 59ffb02 | 2018-11-27 05:30:56 | [diff] [blame] | 165 | * [Web Test Expectations and Baselines](testing/web_test_expectations.md) - |
| 166 | Setting expected results of web tests. |
| 167 | * [Web Tests Tips](testing/web_tests_tips.md) - Best practices for web tests |
Darwin Huang | a8cd3818 | 2019-01-10 11:05:10 | [diff] [blame] | 168 | * [Web Tests with Manual Fallback](testing/web_tests_with_manual_fallback.md) - |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 169 | Writing tests that simulate manual interventions |
Kent Tamura | 59ffb02 | 2018-11-27 05:30:56 | [diff] [blame] | 170 | * [Extending the Web Test Framework](how_to_extend_web_test_framework.md) |
| 171 | * [Fixing Web Test Flakiness](testing/identifying_tests_that_depend_on_order.md) - |
| 172 | Diagnosing and fixing web test flakiness due to ordering dependencies. |
| 173 | * [Running Web Tests using `content_shell`](testing/web_tests_in_content_shell.md) - |
| 174 | Running web tests by hand. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 175 | * [Web Platform Tests](testing/web_platform_tests.md) - Shared tests across |
| 176 | browser vendors |
Joshua Peraza | 6f96b9d | 2019-02-12 16:55:14 | [diff] [blame] | 177 | * [Using Crashpad with `content_shell`](testing/using_crashpad_with_content_shell.md) - |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 178 | Capture stack traces on layout test crashes without an attached debugger |
Lei Lei | 8aa9db62 | 2019-05-01 21:08:01 | [diff] [blame] | 179 | * [Test Descriptions](testing/test_descriptions.md) - Unit test targets that can be |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 180 | built, with associated desciptions. |
Xiaohan Wang | 203c741 | 2019-10-09 23:34:59 | [diff] [blame] | 181 | * [Fuzz Testing](../testing/libfuzzer/README.md) - Fuzz testing in Chromium. |
Lei Lei | 8aa9db62 | 2019-05-01 21:08:01 | [diff] [blame] | 182 | * [IPC Fuzzer](testing/ipc_fuzzer.md) - Fuzz testing of Chromium IPC interfaces. |
| 183 | * [Running Chrome tests with AddressSanitizer (asan) and LeakSanitizer (lsan)](testing/linux_running_asan_tests.md) - |
| 184 | Run Chrome tests with ASAN and LSAN builds to detect addressability issues and memory leaks. |
Yuke Liao | 43bbbcd5 | 2019-06-21 19:34:50 | [diff] [blame] | 185 | * [Code Coverage](testing/code_coverage.md) - Code coverage for Chromium. |
| 186 | * [Code Coverage in Gerrit](testing/code_coverage_in_gerrit.md) - Per-CL code |
| 187 | coverage in Gerrit to assist code reviews. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 188 | |
Kenneth Russell | 9618add | 2018-05-03 03:16:05 | [diff] [blame] | 189 | ### GPU-related docs |
| 190 | * [GPU Pixel Wrangling](gpu/pixel_wrangling.md) - Instructions for GPU |
| 191 | pixel wrangling (the GPU sheriffing rotation). |
| 192 | * [Debugging GPU related code](gpu/debugging_gpu_related_code.md) - Hints for |
| 193 | debugging GPU- and graphics-related code. |
| 194 | * [GPU Testing](gpu/gpu_testing.md) - Description of Chromium's GPU testing |
| 195 | infrastructure. |
| 196 | * [GPU Bot Details](gpu/gpu_testing_bot_details.md) - In-depth description of |
| 197 | how the bots are maintained. |
| 198 | |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 199 | ### Misc Linux-Specific Docs |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 200 | * [Linux Proxy Config](linux/proxy_config.md) - Network proxy sources on Linux |
| 201 | * [Debugging SSL on Linux](linux/debugging_ssl.md) - Tips on debugging SSL |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 202 | code in Linux |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 203 | * [Linux Cert Managment](linux/cert_management.md) - Managing X.509 |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 204 | Certificates in Linux |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 205 | * [Tips for Debugging on Linux](linux/debugging.md) |
| 206 | * [Linux GTK Theme Integration](linux/gtk_theme_integration.md) - Having |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 207 | Chrome match the GTK+ theme. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 208 | * [Browser Plugins on Linux](linux/plugins.md) - A collection of links to |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 209 | information on how browser plugins work on Linux |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 210 | * [Linux Crash Dumping](linux/crash_dumping.md) - How Breakpad uploads crash |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 211 | reports to Google crash servers. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 212 | * [Linux Minidump to Core](linux/minidump_to_core.md) - How to convert a |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 213 | Breakpad-generated minidump files to a core file readable by most debuggersx |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 214 | * [Linux Sandbox IPC](linux/sandbox_ipc.md) - The lower level UPC system used |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 215 | to route requests from the bottom of the call stack up into the browser. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 216 | * [Linux Dev Build as Default Browser](linux/dev_build_as_default_browser.md) - |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 217 | How to configure a Dev build of Chrome as the default browser in Linux. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 218 | * [Linux Chromium Packages](linux/chromium_packages.md) - Packages of Chromium |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 219 | browser (not Chrome) provided by some Linux distributions. |
| 220 | * [`seccomp` Sandbox Crash Dumping](seccomp_sandbox_crash_dumping.md) - Notes |
| 221 | on crash dumping a process running in a seccomp sandbox. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 222 | * [Linux Password Storage](linux/password_storage.md) - Keychain integrations |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 223 | between Chromium and Linux. |
Ivan Sandrk | fe73ee8 | 2018-03-23 11:54:16 | [diff] [blame] | 224 | * [Linux Sublime Development](sublime_ide.md) - Using Sublime as an IDE |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 225 | for Chromium development on Linux. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 226 | * [Building and Debugging GTK](linux/building_debug_gtk.md) - Building |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 227 | Chromium against GTK using lower optimization levels and/or more debugging |
| 228 | symbols. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 229 | * [Debugging GTK](linux/debugging_gtk.md) - Using the GTK Debug packages and |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 230 | related tools. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 231 | * [Chroot Notes](linux/using_a_chroot.md) - Setting up a chroot to work around |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 232 | libfreetype differences in some versions of Linux. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 233 | * [Linux Sandboxing](linux/sandboxing.md) - The Linux multi-process model to |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 234 | isolate browser components with different privileges. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 235 | * [Zygote Process](linux/zygote.md) - How the Linux Zygote process, used to |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 236 | spawn new processes, works. |
Lei Lei | 8aa9db62 | 2019-05-01 21:08:01 | [diff] [blame] | 237 | * [Running Web Tests on Linux](testing/web_tests_linux.md) - Linux-specific |
Kent Tamura | 59ffb02 | 2018-11-27 05:30:56 | [diff] [blame] | 238 | instructions for running web tests. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 239 | * [Linux Sysroot Images](linux/sysroot.md) - How builds use libraries on Linux |
| 240 | * [Linux Hardware Video Decoding](linux/hw_video_decode.md) - Enabling |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 241 | hardware video decode codepaths on Linux |
| 242 | |
| 243 | ### Misc MacOS-Specific Docs |
| 244 | * [Using CCache on Mac](ccache_mac.md) - Speed up builds on Mac using ccache |
| 245 | with clang/ninja |
| 246 | * [Cocoa tips and tricks](cocoa_tips_and_tricks.md) - A collection of idioms |
| 247 | used when writing Cocoa views and controllers |
| 248 | * [MacViews Release Plan](ui/views/macviews_release.md) |
| 249 | |
| 250 | ### Misc Windows-Specific Docs |
| 251 | * [Handling cygwin rebaseall failures](cygwin_dll_remapping_failure.md) |
| 252 | * [Hacking on ANGLE in Chromium](angle_in_chromium.md) - OpenGL ES 2.0 built |
| 253 | on top of DirectX |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 254 | * [Windows Split DLLs](windows_split_dll.md) - Splitting `chrome.dll` into |
| 255 | multiple dlls to work around toolchain limitations on Windows. |
| 256 | |
| 257 | ### Misc Android-Specific Docs |
| 258 | * [Google Play Services in Chrome for Android](google_play_services.md) |
| 259 | * [Accessing C++ Enums in Java](android_accessing_cpp_enums_in_java.md) - How |
| 260 | to use C++-defined enums in Java code |
| 261 | * [Profiling Content Shell on Android](profiling_content_shell_on_android.md) - |
| 262 | Setting up profiling for `content_shell` on Android |
| 263 | * [Working Remotely with Android](working_remotely_with_android.md) - Building |
| 264 | on a remote machine for an Android device connected to your local machine |
Lei Lei | 8aa9db62 | 2019-05-01 21:08:01 | [diff] [blame] | 265 | * [Android Test Instructions](testing/android_test_instructions.md) - Running a build |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 266 | on an Android device or emulator. |
| 267 | * [Android Debugging](android_debugging_instructions.md) - Tools and tips for |
| 268 | how to debug Java and/or C/C++ code running on Android. |
| 269 | * [Android Logging](android_logging.md) - How Chrome's logging API works with |
| 270 | `android.util.Log` on Android, and usage guidelines. |
| 271 | * [Chromoting Android Hacking](chromoting_android_hacking.md) - Viewing the |
| 272 | logs and debugging the Chrome Remote Desktop Android client. |
David 'Digit' Turner | 40560ef7 | 2018-03-07 09:44:28 | [diff] [blame] | 273 | * [Android Java Static Analysis](../build/android/docs/lint.md) - Catching |
| 274 | Java related issues at compile time with the 'lint' tool. |
| 275 | * [Java Code Coverage](../build/android/docs/coverage.md) - Collecting code |
| 276 | coverage data with the EMMA tool. |
| 277 | * [Android BuildConfig files](../build/android/docs/build_config.md) - |
| 278 | What are .build_config files and how they are used. |
David 'Digit' Turner | 9094474 | 2018-08-03 13:22:08 | [diff] [blame] | 279 | * [Android App Bundles](../build/android/docs/android_app_bundles.md) - |
| 280 | How to build Android app bundles for Chrome. |
Tibor Goldschwendt | 19364ba | 2019-04-10 15:59:55 | [diff] [blame] | 281 | * [Dynamic Feature Modules (DFMs)](android_dynamic_feature_modules.md) - How |
| 282 | to create dynamic feature modules. |
Theresa Wellington | b0767a7 | 2019-10-01 00:17:46 | [diff] [blame] | 283 | * [Chrome for Android UI](ui/android/overview.md) - Resources and best practices for |
| 284 | developing UI |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 285 | |
| 286 | ### Misc iOS-Specific Docs |
| 287 | * [Continuous Build and Test Infrastructure for Chromium for iOS](ios/infra.md) |
| 288 | * [Opening links in Chrome for iOS](ios/opening_links.md) - How to have your |
| 289 | iOS app open links in Chrome. |
| 290 | * [User Agent in Chrome for iOS](ios/user_agent.md) - Notes on User Agent |
| 291 | strings using Chrome for iOS. |
Mike Baxley | 47db7d8 | 2017-11-16 15:57:17 | [diff] [blame] | 292 | * [Running iOS test suites locally](ios/testing.md) |
Mark Cogan | 0abda965 | 2020-04-15 11:22:07 | [diff] [blame] | 293 | * [Working With Project Files in iOS](ios/working_with_files.md) - How |
| 294 | to add, remove, and rename files in the iOS Chromium project. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 295 | |
Daniel Erat | ace8d362 | 2017-12-20 23:27:24 | [diff] [blame] | 296 | ### Misc Chrome-OS-Specific Docs |
Jacob Dufault | 4260b148 | 2019-04-29 23:17:24 | [diff] [blame] | 297 | * [Setting up captive portals and other restrictive networks](login/restrictive_networks.md) |
Denis Kuznetsov | 885b185 | 2019-05-15 19:07:48 | [diff] [blame] | 298 | * [Enterprise Enrollment](enterprise/enrollment.md) |
| 299 | * [Kiosk mode and public sessions](enterprise/kiosk_public_session.md) |
Jacob Dufault | 4260b148 | 2019-04-29 23:17:24 | [diff] [blame] | 300 | * [Debugging UI in OOBE/login/lock](login/ui_debugging.md) |
Daniel Erat | ace8d362 | 2017-12-20 23:27:24 | [diff] [blame] | 301 | * [Chrome Logging on Chrome OS](chrome_os_logging.md) |
| 302 | |
Dan Beam | 1981221 | 2018-11-29 08:16:56 | [diff] [blame] | 303 | ### Misc WebUI-Specific Docs |
| 304 | * [Creating WebUI Interfaces in components/](webui_in_components.md) How to |
| 305 | create a new WebUI component in the `components/` directory. |
| 306 | |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 307 | ### Media |
| 308 | * [Audio Focus Handling](media/audio_focus.md) - How multiple MediaSession |
| 309 | audio streams interact |
| 310 | * [Autoplay of HTMLMediaElements](media/autoplay.md) - How HTMLMediaElements |
| 311 | are autoplayed. |
| 312 | * [Piranha Plant](piranha_plant.md) - Future architecture of MediaStreams |
David Staessens | 4f491087 | 2019-10-28 03:18:51 | [diff] [blame] | 313 | * [Video Encode Accelerator Tests](media/gpu/veatest_usage.md) - How to |
| 314 | use the accelerated video encoder test program. |
David Staessens | f3404c1 | 2019-04-16 00:12:05 | [diff] [blame] | 315 | * [Video Decoder Tests](media/gpu/video_decoder_test_usage.md) - Running the |
David Staessens | 4f491087 | 2019-10-28 03:18:51 | [diff] [blame] | 316 | video decoder tests. |
David Staessens | 80711e8 | 2019-04-16 00:23:14 | [diff] [blame] | 317 | * [Video Decoder Performance Tests](media/gpu/video_decoder_perf_test_usage.md) - |
David Staessens | 4f491087 | 2019-10-28 03:18:51 | [diff] [blame] | 318 | Running the video decoder performance tests. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 319 | |
| 320 | ### Accessibility |
| 321 | * [Accessibility Overview](accessibility/overview.md) - Overview of |
| 322 | accessibility concerns and approaches in Chromium. |
| 323 | * [Accessibility Tests](accessibility/tests.md) - Where to find |
| 324 | accessibility-related tests in the codebase. |
| 325 | * [ChromeVox on Chrome OS](accessibility/chromevox.md) - Enabling spoken |
| 326 | feedback (ChromeVox) on Chrome OS. |
| 327 | * [ChromeVox on Desktop Linux](accessibility/chromevox_on_desktop_linux.md) - |
| 328 | Enabling spoken feedback (ChromeVox) on desktop Linux. |
Katie D | ed1a997 | 2018-04-17 16:22:18 | [diff] [blame] | 329 | * [Offscreen, Invisible and Size](accessibility/offscreen.md) - How Chrome |
| 330 | defines offscreen, invisible and size in the accessibility tree. |
erikchen | b83e010a | 2018-10-08 21:34:01 | [diff] [blame] | 331 | * [Text to Speech](accessibility/tts.md) - Overview of text to speech in |
Katie D | ed1a997 | 2018-04-17 16:22:18 | [diff] [blame] | 332 | Chrome and Chrome OS. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 333 | * [BRLTTY in Chrome OS](accessibility/brltty.md) - Chrome OS integration with |
| 334 | BRLTTY to support refreshable braille displays |
| 335 | * [PATTS on Chrome OS](accessibility/patts.md) - Notes on the PATTS speech |
| 336 | sythesis engine used on Chrome OS |
| 337 | * [VoiceOver](ios/voiceover.md) - Using Apple's VoiceOver feature with |
| 338 | Chromium on iOS. |
| 339 | |
Erik Chen | cd19c16 | 2018-04-21 00:27:24 | [diff] [blame] | 340 | ### Memory |
| 341 | * [Memory Overview](memory/README.md) |
| 342 | |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 343 | ### Memory Infrastructure Timeline Profiling (MemoryInfra) |
| 344 | * [Overview](memory-infra/README.md) |
| 345 | * [GPU Profiling](memory-infra/probe-gpu.md) |
| 346 | * [Adding Tracing to a Component](memory-infra/adding_memory_infra_tracing.md) |
| 347 | * [Enabling Startup Tracing](memory-infra/memory_infra_startup_tracing.md) |
| 348 | * [Memory Usage in CC](memory-infra/probe-cc.md) |
| 349 | * [Memory Benchmarks](memory-infra/memory_benchmarks.md) |
| 350 | * [Heap Profiling](memory-infra/heap_profiler.md) |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 351 | |
Ilya Sherman | 3cb2087e | 2020-09-17 17:30:56 | [diff] [blame] | 352 | ### Metrics |
| 353 | * [Histograms](/tools/metrics/histograms/README.md) |
| 354 | * [User Actions](/tools/metrics/actions/README.md) |
| 355 | * [Code review guidelines](/tools/metrics/histograms/review_guidelines.md) |
| 356 | |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 357 | ### Misc |
| 358 | * [Useful URLs](useful_urls.md) - A collection of links to various tools and |
| 359 | dashboards |
| 360 | * [ERC IRC](erc_irc.md) - Using ERC in EMACS to access IRC |
| 361 | * [Kiosk Mode](kiosk_mode.md) - Simulating kiosk mode. |
| 362 | * [User Handle Mapping](user_handle_mapping.md) - Names of developers across |
| 363 | Chromium/IRC/Google |
| 364 | * [Documentation Best Practices](documentation_best_practices.md) |
| 365 | * [Documentation Guidelines](documentation_guidelines.md) |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 366 | * [Chromium Browser vs Google Chrome](chromium_browser_vs_google_chrome.md) - |
| 367 | What's the difference between _Chromium Browser_ and _Google Chrome_? |
Jochen Eisinger | 3199b01 | 2019-04-04 15:37:29 | [diff] [blame] | 368 | * [Google Chrome branded builds](google_chrome_branded_builds.md) |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 369 | * [Proxy Auto Config using WPAD](proxy_auto_config.md) - How WPAD servers are |
| 370 | used to automatically set proxy settings. |
| 371 | * [Installing Chromium OS on VMWare](installation_at_vmware.md) - How to |
| 372 | install Chromium OS on VMWare. |
Steve Kobes | 22fb19c | 2017-07-05 21:49:08 | [diff] [blame] | 373 | * [User Data Directory](user_data_dir.md) - How the user data and cache |
| 374 | directories are determined on all platforms. |
Greg Thompson | 47bdc67 | 2020-01-06 14:25:31 | [diff] [blame] | 375 | * [User Data Storage](user_data_storage.md) - Policy documentation for files in User Data. |
Ken Rockot | ab03512 | 2019-02-06 00:35:24 | [diff] [blame] | 376 | |
| 377 | ### Mojo & Services |
| 378 | * [Intro to Mojo & Services](mojo_and_services.md) - Quick introduction |
| 379 | to Mojo and services in Chromium, with examples |
| 380 | * [Mojo API Reference](/mojo/README.md) - Detailed reference documentation for |
| 381 | all things Mojo |
Ken Rockot | ab03512 | 2019-02-06 00:35:24 | [diff] [blame] | 382 | * [Service Development Guidelines](/services/README.md) - Guidelines for |
| 383 | service development in the Chromium tree |
| 384 | * [Servicifying Chromium Features](servicification.md) - General advice for |
| 385 | integrating new and existing subsystems into Chromium as services |
| 386 | * [Converting Legacy IPC to Mojo](mojo_ipc_conversion.md) - Tips and common |
| 387 | patterns for practical IPC conversion work |
Oksana Zhuravlova | 437d8a8 | 2019-02-26 00:25:50 | [diff] [blame] | 388 | * [Mojo “Style” Guide](security/mojo.md) - Recommendations for best practices |
| 389 | from Mojo and IPC reviewers |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 390 | |
Nicolás Peña Moreno | c7391bb | 2020-04-30 22:17:12 | [diff] [blame] | 391 | ### Speed |
| 392 | * [Chrome Speed](speed/README.md) - Documentation for performance measurements and regressions in Chrome. |
| 393 | * [Chrome Speed Metrics](speed_metrics/README.md) - Documentation about user experience metrics in the web and their JavaScript APIs. |
| 394 | |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 395 | ### Probably Obsolete |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 396 | * [TPM Quick Reference](tpm_quick_ref.md) - Trusted Platform Module notes. |
| 397 | * [System Hardening Features](system_hardening_features.md) - A list of |
| 398 | current and planned Chrome OS security features. |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 399 | * [WebView Policies](webview_policies.md) |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 400 | * [Linux Profiling](linux/profiling.md) - How to profile Chromium on Linux |
| 401 | * [Linux Graphics Pipeline](linux/graphics_pipeline.md) |
| 402 | * [Linux `SUID` Sandbox](linux/suid_sandbox.md) - Sandboxing renderers using a |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 403 | SUID binary on Linux |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 404 | * [Linux `SUID` Sandbox Development](linux/suid_sandbox_development.md) - |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 405 | Development on the above system. |
Tom Anderson | 93e49e49 | 2019-12-23 19:55:37 | [diff] [blame] | 406 | * [Linux PID Namespace Support](linux/pid_namespace_support.md) |
justincarlson | 90a1c8c | 2017-04-14 00:34:25 | [diff] [blame] | 407 | * [Vanilla msysgit workflow](vanilla_msysgit_workflow.md) - A workflow for |
| 408 | using mostly vanilla git on Windows. |
| 409 | * [Old Chromoting Build Instructions](old_chromoting_build_instructions.md) |
| 410 | * [Old Options](chrome_settings.md) - Pre-Material Design chrome://settings |
| 411 | notes. |