diff options
-rw-r--r-- | .gitlab-ci.yml | 2 | ||||
-rwxr-xr-x[-rw-r--r--] | .gitlab/fix-submodules.py | 48 |
2 files changed, 48 insertions, 2 deletions
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index a18757b3dc..67b28305f0 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -119,7 +119,7 @@ validate-x86_64-darwin: LANG: "en_US.UTF-8" before_script: - git clean -xdf && git submodule foreach git clean -xdf - - python .gitlab/fix-submodules.py + - python3 .gitlab/fix-submodules.py - git submodule sync --recursive - git submodule update --init --recursive - git checkout .gitmodules diff --git a/.gitlab/fix-submodules.py b/.gitlab/fix-submodules.py index 2ff8e41974..621d692edb 100644..100755 --- a/.gitlab/fix-submodules.py +++ b/.gitlab/fix-submodules.py @@ -1,8 +1,54 @@ -#!/usr/bin/python +#!/usr/bin/env python3 +""" +Fix submodule upstream URLs. This ensures that CI builds of GHC forks +clone their submodules from its usual location. Otherwise users would need to +fork all submodules before their CI builds would succeed. +""" + +from typing import List, Dict +from pathlib import Path import re x = open('.gitmodules').read() x = re.sub(r"url *= *\.\.", "url = https://gitlab.haskell.org/ghc", x) open('.gitmodules', 'w').write(x) +import subprocess + +def get_configs(config_file: Path) -> Dict[str, str]: + args = ['git', 'config', '-f', config_file.as_posix(), '--list'] + out = subprocess.check_output(args) + configs = {} + for line in out.decode('UTF-8').split('\n'): + if '=' in line: + k,v = line.split('=') + configs[k] = v + + return configs + +def set_config(config_file: Path, key: str, value: str) -> None: + args = ['git', 'config', '-f', config_file.as_posix(), '--replace', key, value] + subprocess.check_call(args) + +upstreams = { + 'utils/haddock': 'https://github.com/haskell/haddock' +} + +modules_config = Path('.gitmodules') + +def main(): + for k,v in get_configs(modules_config).items(): + match = re.match('submodule\.(.+)\.url', k) + if match is not None: + submod = match.group(1) + if submod in upstreams: + url = upstreams[submod] + else: + url = re.sub('\.\.', 'https://gitlab.haskell.org/ghc', v) + + print('Using {submod} from {url}'.format(submod=submod, url=url)) + set_config(modules_config, k, url) + +if __name__ == '__main__': + main() |