78 lines
3.7 KiB
Markdown
78 lines
3.7 KiB
Markdown
|
# Choosing an ANGLE branch for your project
|
||
|
|
||
|
ANGLE is under continuous development, and does not create release tarballs or
|
||
|
tag specific revisions as releases, which may make the process of choosing a
|
||
|
point in ANGLE's history as the dependency for your project less than obvious.
|
||
|
This document illustrates how to choose a branch of ANGLE which can be expected
|
||
|
to be updated with critical fixes, should they be needed.
|
||
|
|
||
|
## ANGLE automatic branching
|
||
|
|
||
|
Branches are created automatically in ANGLE to correspond to branches created in
|
||
|
Chromium. These branches are named `chromium/####`, where the number is the
|
||
|
matching Chromium branch. These branches will be created from the revision which
|
||
|
that Chromium branch points to as its dependency. So, for example, the
|
||
|
`chromium/2013` branch point is at r28bcf4ff, because [Chromium's dependency
|
||
|
file for the 2013 branch]
|
||
|
(http://src.chromium.org/viewvc/chrome/branches/2013/src/DEPS?revision=272741)
|
||
|
uses this ANGLE revision.
|
||
|
|
||
|
It isn't necessary to be familiar with how Chromium's dependency management
|
||
|
works to choose an appropriate ANGLE branch for your project. You will, however,
|
||
|
likely want to make sure that you choose a branch that is used for a relatively
|
||
|
stable Chromium release channel build, as those branches will be deployed with
|
||
|
Chromium, and receive updates if bugs are found and fixed during release
|
||
|
lifetime, while the more volatile channels will turn over quickly, and their
|
||
|
branches will be short-lived.
|
||
|
|
||
|
**We recommend choosing a branch corresponding to a Beta or Stable Chromium
|
||
|
release** if you are pursuing periodic, not continuous, integration of ANGLE.
|
||
|
|
||
|
## Matching a Chromium release to an ANGLE branch
|
||
|
|
||
|
In order to determine which branches are used by Chromium releases, please use
|
||
|
[the OmahaProxy tool](http://omahaproxy.appspot.com/), which lists build
|
||
|
information about current Chromium releases. Find the entry for a suitable
|
||
|
release channel (for now, we recommend one of the Windows desktop releases), and
|
||
|
note the branch listed in the `true_branch` column. This identifies the ANGLE
|
||
|
branch used by that Chromium release.
|
||
|
|
||
|
## Updates to release branches
|
||
|
|
||
|
If bugs (stability, security, performance, or otherwise) are discovered after a
|
||
|
branch has been created, and that branch is used by a Chromium release, the
|
||
|
fixes for those bugs will be applied to the ANGLE branches for uptake by
|
||
|
Chromium and any other projects using that branch. You should need only to
|
||
|
perform a `git pull` to check for and apply any such changes.
|
||
|
|
||
|
## Cherry-picking a change to a release branch
|
||
|
|
||
|
Occasionally a bug fix must be merged back to an earlier Chromium
|
||
|
release branch. To do this, first look up the branch number in
|
||
|
[OmahaProxy](https://omahaproxy.appspot.com/). For example, M55
|
||
|
corresponds to branch number 2883.
|
||
|
|
||
|
In the simple case where there are no conflicts, the merge can be done
|
||
|
entirely in the Gerrit UI. Click the "Cherry pick" button and enter
|
||
|
`chromium/[branch_number]` as the branch to merge to.
|
||
|
|
||
|
If there are conflicts, however, follow these steps:
|
||
|
|
||
|
1. `git checkout chromium/[branch_number]`
|
||
|
2. `git cherry-pick [commit_hash]`
|
||
|
3. Fix any merge conflicts.
|
||
|
4. `git cl upload`
|
||
|
|
||
|
Have the cherry-pick reviewed, and then land it. It's also OK to skip
|
||
|
the review and land it yourself with TBR= in the issue description, if
|
||
|
you have that ability.
|
||
|
|
||
|
There is one final step to pick up the ANGLE change into a Chromium Beta or
|
||
|
Stable branch. A Skia auto-roller updates the DEPS file in the corresponding
|
||
|
Chromium branch automatically once the ANGLE change is merged into an ANGLE
|
||
|
branch. To make sure that your change has made it into Chromium you can check
|
||
|
these auto-rollers:
|
||
|
|
||
|
1. https://autoroll.skia.org/r/angle-chromium-beta-autoroll
|
||
|
1. https://autoroll.skia.org/r/angle-chromium-stable-autoroll
|