initial updates from meeting today
This commit is contained in:
parent
0711e1e5e1
commit
be67fcf62b
1 changed files with 102 additions and 46 deletions
|
@ -3,51 +3,112 @@
|
||||||
This document is meant to serve as an overview of what steps are needed
|
This document is meant to serve as an overview of what steps are needed
|
||||||
on each Chromium upgrade in Electron.
|
on each Chromium upgrade in Electron.
|
||||||
|
|
||||||
## Update libchromiumcontent (a.k.a. libcc)
|
- Upgrade libcc to a new Chromium version
|
||||||
|
- Make Electron code compatible with the new libcc
|
||||||
|
- Update Electron dependencies (crashpad, NodeJS, etc.) if needed
|
||||||
|
- Make internal builds of libcc and electron
|
||||||
|
- Update Electron docs if necessary
|
||||||
|
|
||||||
- Clone the repo:
|
|
||||||
```sh
|
|
||||||
git clone git@github.com:electron/libchromiumcontent.git
|
|
||||||
cd libchromiumcontent
|
|
||||||
```
|
|
||||||
- Run bootstrap script to init and sync git submodules:
|
|
||||||
```sh
|
|
||||||
./script/bootstrap -v
|
|
||||||
```
|
|
||||||
- Update `VERSION` file to correspond to Chromium version.
|
|
||||||
- Run `script/update`, it will probably fail applying patches.
|
|
||||||
- Fix failing patches. `script/patch.py` might help.
|
|
||||||
- Don't forget to fix patches in the `patches-mas/` folder.
|
|
||||||
- Build libcc:
|
|
||||||
```sh
|
|
||||||
./script/build
|
|
||||||
```
|
|
||||||
- Create dist folders which will be used by electron:
|
|
||||||
```sh
|
|
||||||
./script/create-dist --no_zip
|
|
||||||
cd dist/main
|
|
||||||
../../tools/generate_filenames_gypi filenames.gypi src shared_library static_library
|
|
||||||
cd -
|
|
||||||
```
|
|
||||||
- Open a pull request to `electron/libchromiumcontent` with the changes.
|
|
||||||
- Fix compilation on the all supported platforms/arches.
|
|
||||||
|
|
||||||
## Update Electron
|
## Upgrade `libcc` to a new Chromium
|
||||||
|
|
||||||
- Set `vendor/libchromiumcontent` revision to a version with the new Chromium.
|
### Steps
|
||||||
- It will be great if GH builds for this libcc version are already green
|
1. Get the code and initialize the project:
|
||||||
and its archives are already available. Otherwise everyone would need
|
- ```
|
||||||
to build libcc locally in order to try build a new Electron.
|
$ git clone git@github.com:electron/libchromiumcontent.git
|
||||||
- Set `CLANG_REVISION` in `script/update-clang.sh` to match the version
|
$ cd libchromiumcontent
|
||||||
Chromium is using. You can find it in file `src/tools/clang/scripts/update.py` in updated `electron/libchromiumcontent` repo.
|
$ ./script/bootstrap -v
|
||||||
- Run `script/bootstrap.py`.
|
```
|
||||||
- Upgrade Node.js if you are willing to. See the notes below.
|
2. Get a new beta/stable Chromium revision from OmahaProxy
|
||||||
- Fix compilation.
|
3. Put it into the VERSION file, then run `$ ./script/update`
|
||||||
- Open a pull request on `electron/electron` with the changes.
|
- It will probably fail applying patches.
|
||||||
- This should include upgrading the submodules in `vendor/` as needed.
|
4. Fix `*.patch` files in the `/patches` and `/patches-mas` folders.
|
||||||
- Fix failing tests.
|
5. (Optional) Run a separate script to apply patches (`script/update` uses it internally):
|
||||||
|
- `$ ./script/apply-patches`
|
||||||
|
- There is also another script `/script/patch.py` that could be more useful, check `--help` to learn how it works with `$ ./script/patch.py -h`
|
||||||
|
6. Run the build when all patches can be applied without errors
|
||||||
|
`$ ./script/build`
|
||||||
|
- If some patches are no longer compatible with the Chromium code, fix compilation errors.
|
||||||
|
7. When build succeeds, create a `dist` for Electron
|
||||||
|
`$ ./script/create-dist --no_zip`
|
||||||
|
- It will create `dist/main` folder in the root of the libcc repo, you will need it to build Electron.
|
||||||
|
8. (Optional) Update script contents if there are errors resultant of some files being removed or renamed. (`--no_zip` prevents script from create `dist` archives, you don't need them.)
|
||||||
|
|
||||||
## Upgrade Node.js
|
|
||||||
|
## Update Electron Code
|
||||||
|
|
||||||
|
### Steps
|
||||||
|
1. Get the code:
|
||||||
|
- ```
|
||||||
|
$ git clone git@github.com:electron/electron.git
|
||||||
|
$ cd electron
|
||||||
|
```
|
||||||
|
2. If you already have libcc built on you machine in its own repo, you need to tell Electron explicitly to use it:
|
||||||
|
- ```
|
||||||
|
$ ./script/bootstrap.py -v \
|
||||||
|
--libcc_source_path <libcc_folder>/src \
|
||||||
|
--libcc_shared_library_path <libcc_folder>/shared_library \
|
||||||
|
--libcc_static_library_path <libcc_folder>/static_library
|
||||||
|
```
|
||||||
|
- If you haven't yet built libcc but it's already supposed to be upgraded to a new Chromium, bootstrap Electron as usual
|
||||||
|
- `$ ./script/bootstrap.py -v`
|
||||||
|
- Ensure that libcc submodule (`vendor/libchromiumcontent`) points to a right revision
|
||||||
|
|
||||||
|
3. Set CLANG_REVISION in` script/update-clang.sh` to match the version Chromium is using.
|
||||||
|
- Located in `electron/libchromiumcontent/src/tools/clang/scripts/update.py`
|
||||||
|
|
||||||
|
4. Checkout Chromium if you haven't already: https://chromium.googlesource.com/chromium/src.git/+/{VERSION}/tools/clang/scripts/update.py
|
||||||
|
- (Replace the `{VERSION}` placeholder in the url above to the Chromium version libcc uses.)
|
||||||
|
5. Build Electron.
|
||||||
|
- Try to build Debug version first: `$ ./script/build.py -c D`
|
||||||
|
- You will need it to run tests
|
||||||
|
6. Fix compilation and linking errors
|
||||||
|
7. Ensure that Release build can be built too: `$ ./script/build.py -c R`
|
||||||
|
- Often you will have different linking errors in Release build, fix them too.
|
||||||
|
-Some compilation and linking errors are caused by missing source/object files in the libcc `dist`
|
||||||
|
8. Update `./script/create-dist` in the libcc repo, recreate a `dist`, and run Electron bootstrap script once again.
|
||||||
|
|
||||||
|
#### Tips for fixing compilation errors
|
||||||
|
- Fix build config errors first
|
||||||
|
- Fix fatal errors first, like missing files and errors related to compiler flags or defines
|
||||||
|
- Try to identify complex errors as soon as possible,
|
||||||
|
- Ask for help if you're not sure how to fix them
|
||||||
|
- Disable all Electron features, fix the build, then enable them one by one
|
||||||
|
- Add more build flags to disable features in build-time.
|
||||||
|
|
||||||
|
When Electron successfully builds in a Debug configuration, try to run tests:
|
||||||
|
`$ ./script/test.py`
|
||||||
|
Fix the failing tests.
|
||||||
|
|
||||||
|
Follow all the steps above to fix Electron code on all supported platforms.
|
||||||
|
|
||||||
|
|
||||||
|
## Update Crashpad
|
||||||
|
|
||||||
|
- Electron's crashpad fork: https://github.com/electron/crashpad
|
||||||
|
- Primary crashpad repo: https://chromium.googlesource.com/crashpad/crashpad/
|
||||||
|
|
||||||
|
|
||||||
|
### Steps
|
||||||
|
If there are any compilation errors related to the Crashpad, it probably means you need to update the fork to a newer revision:
|
||||||
|
|
||||||
|
1. Clone Electron's fork of the Crashpad, add the main repo as another remote:
|
||||||
|
- ```$ git clone https://github.com/electron/crashpad && cd crashpad
|
||||||
|
$ git remote add upstream https://chromium.googlesource.com/crashpad/crashpad/ && git fetch upstream
|
||||||
|
```
|
||||||
|
2. Find a revision Chromium uses in src/third_party/crashpad/README.chromium
|
||||||
|
3. Rebase the master branch to that REVISION
|
||||||
|
- `$ git rebase REVISION`
|
||||||
|
- If there are nontrivial conflicts during rebase, consult with the commit's author.
|
||||||
|
4. Add a tag with the next Electron version to a top commit in the master branch
|
||||||
|
- e.g. if current Electron version is `1.11.*`, then use tag `electron-1.12.0`, because it will be used in the next version.
|
||||||
|
5. Ensure Electron-specific commits in the master branch on GitHub are properly tagged
|
||||||
|
- If they aren't, force push will make them orphans and they'll be lost.
|
||||||
|
6. Force push to Electron's crashpad fork.
|
||||||
|
7. Update `/vendor/crashpad` submodule in the Electron's upgrade branch to point to the updated crashpad.
|
||||||
|
|
||||||
|
|
||||||
|
## Update NodeJS
|
||||||
|
|
||||||
- Upgrade `vendor/node` to the Node release that corresponds to the v8 version
|
- Upgrade `vendor/node` to the Node release that corresponds to the v8 version
|
||||||
being used in the new Chromium release. See the v8 versions in Node on
|
being used in the new Chromium release. See the v8 versions in Node on
|
||||||
|
@ -56,11 +117,6 @@ cd -
|
||||||
If it's not available check `v8/include/v8-version.h`
|
If it's not available check `v8/include/v8-version.h`
|
||||||
in the Chromium checkout.
|
in the Chromium checkout.
|
||||||
|
|
||||||
## Troubleshooting
|
|
||||||
|
|
||||||
**TODO**
|
|
||||||
|
|
||||||
|
|
||||||
## Verify ffmpeg Support
|
## Verify ffmpeg Support
|
||||||
|
|
||||||
Electron ships with a version of `ffmpeg` that includes proprietary codecs by
|
Electron ships with a version of `ffmpeg` that includes proprietary codecs by
|
||||||
|
|
Loading…
Reference in a new issue