Skip to content

Commit 5948e62

Browse files
committed
Sync LLVM submodule if it has been initialized
Since having enabled the download-ci-llvm option, and having rebased on top of f05b47c, I've noticed that I had to update the llvm-project submodule manually if it was checked out. Orignally, the submodule update logic was introduced to reduce the friction for contributors to manage the submodules, or in other words, to prevent getting PRs that have unwanted submodule rollbacks because the contributors didn't run git submodule update. This commit adds logic to ensure there is no inadvertent LLVM submodule rollback in a PR if download-ci-llvm (or llvm-config) is enabled. It will detect whether the llvm-project submodule is initialized, and if so, update it in any case. If it is not initialized, behaviour is kept to not do any update/initialization. An alternative to the chosen implementation would be to not pass the --init command line arg to `git submodule update` for the src/llvm-project submodule. This would show a confusing error message however on all builds with an uninitialized repo. We could pass the --silent param, but we still want it to print something if it is initialized and has to update something. So we just do a manual check for whether the submodule is initialized.
1 parent 4d247ad commit 5948e62

File tree

1 file changed

+6
-1
lines changed

1 file changed

+6
-1
lines changed

src/bootstrap/bootstrap.py

+6-1
Original file line numberDiff line numberDiff line change
@@ -891,10 +891,15 @@ def update_submodules(self):
891891
).decode(default_encoding).splitlines()]
892892
filtered_submodules = []
893893
submodules_names = []
894+
llvm_checked_out = os.path.exists(os.path.join(self.rust_root, "src/llvm-project/.git"))
894895
for module in submodules:
895896
if module.endswith("llvm-project"):
897+
# Don't sync the llvm-project submodule either if an external LLVM
898+
# was provided, or if we are downloading LLVM. Also, if the
899+
# submodule has been initialized already, sync it anyways so that
900+
# it doesn't mess up contributor pull requests.
896901
if self.get_toml('llvm-config') or self.downloading_llvm():
897-
if self.get_toml('lld') != 'true':
902+
if self.get_toml('lld') != 'true' and not llvm_checked_out:
898903
continue
899904
check = self.check_submodule(module, slow_submodules)
900905
filtered_submodules.append((module, check))

0 commit comments

Comments
 (0)