You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
depot_tools/bootstrap/win
phajdan.jr 6d0a5acdc4 Add git_bootstrap.py, which bootstraps git on Windows using CIPD
It's backwards compatible with the logic in win_tools.bat
and is intended to eventually replace it.

BUG=635421, 629679

Review-Url: https://codereview.chromium.org/2254843004
9 years ago
..
README.md
get_file.js
git-bash.template.sh
git.template.bat
git_bootstrap.py Add git_bootstrap.py, which bootstraps git on Windows using CIPD 9 years ago
git_version.txt
git_version_bleeding_edge.txt
profile.d.python.sh
pylint.new.bat
python276.new.bat
svn.new.bat
svnversion.new.bat
unzip.js
win_tools.bat

README.md

Windows binary tool bootstrap

This directory has the 'magic' for the depot_tools windows binary update mechanisms.

Software bootstrapped

Mechanism

Any time a user runs gclient on windows, it will invoke the depot_tools autoupdate script depot_tools.bat. This, in turn, will run win_tools.bat, which does the bulk of the work.

win_tools.bat will successively look to see if the local version of the binary package is present, and if so, if it's the expected version. If either of those cases is not true, it will download and unpack the respective binary.

Downloading is done with get_file.js, which is a windows script host javascript utility to vaguely impersonate wget.

Through a comedy of history, each binary is stored and retrieved differently.

Git

Git installs are mirrored versions of the offical Git-for-Windows Portable releases.

  • Original: https://github.com/git-for-windows/git/releases
  • Mirror: gs://chrome-infra/PortableGit*.7z.exe

Updating git version

  1. Download the new PortableGit-X.Y.Z-{32,64}.7z.exe from the git-for-windows release page.
  2. From either console.developers.google.com or the CLI, do: 1. Upload those to the gs://chrome-infra Google Storage bucket. 1. Set the allUsers Reader permission (click the "Public link" checkbox next to the binaries).
  3. Edit the git_version.txt or git_version_bleeding_edge.txt file to be the new version. 1. You can use the bleeding edge version to get early feedback/stage a rollout/etc. Users can select this version by 'touch'ing the .git_bleeding_edge file in the root depot_tools directory.
  4. Commit the CL.

Note that in order for the update to take effect, gclient currently needs to run twice. The first time it will update the depot_tools repo, and the second time it will see the new git version and update to it. This is a bug that should be fixed, in case you're reading this and this paragraph infuriates you more than the rest of this README.

Python

Python installs are sourced from gs://chrome-infra/python276_bin.zip .

The process to create them is sort-of-documented in the README of the python zip file.

Subversion

Subversion installs are sourced from gs://chrome-infra/svn_bin.zip .

There will likely never be an update to SVN in depot_tools from the current version.