Skip to content

Latest commit

 

History

History
71 lines (56 loc) · 3.76 KB

google_chrome_branded_builds.md

File metadata and controls

71 lines (56 loc) · 3.76 KB

Google Chrome branded builds

Note: to do any of this, an src-internal checkout is needed. For more info, see http://go/chrome-linux-build#optional-add-src-internal-to-the-checkout

By default, chromium will build with the open source chromium assets and branding (is_chrome_branded = false in GN args, see also Chrome vs. Chromium).

The main reason for this is that the Google Chrome logo and related assets is a trademark which we don't want to release under Chromium's open source license.

Therefore, if you want to add a trademarked resource, check it into an internal repository (see section below), and pick a resource based on the branding (is_chrome_branded in GN, #if BUILDFLAG(GOOGLE_CHROME_BRANDING) in cpp, <if expr="_google_chrome"> in grit preprocessing). If possible, check an open source version into Chromium, so the feature continues to work as expected in the open source build.

E.g. //components/resources/default_100_percent/chromium vs //components/resources/default_100_percent/google_chrome.

For strings, it’s ok to check them into the open source repository, but make sure that you refer to the correct product, i.e., check in a version of the string that says “Google Chrome” and a version that says “Chromium”.

E.g. //chrome/app/chromium_strings.grd vs //chrome/app/google_chrome_strings.grd.

Internal asset repositories

Assets live in various locations based on where they are used: native vs WebUI, chrome vs component layer, etc. You can read more about this here: chromium.org | High DPI Resources

To check in product-specific assets, in general:

Each google_chrome version of a product directory points to a separate internal git repo. Some examples:

To add resources there, cd to this repo, add your new assets and git cl upload to start an internal code review. Once it lands, you will need to create a roll CL for the //../src-internal/DEPS, using roll-dep.

Once that CL lands, an auto-roller bot will update the main repo's src-internal hash reference in //DEPS (example autoroll CL) and your new internal resources will be available on the bots. The chromium-side CL making use of it can then be uploaded.