aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/msubprojects.py
diff options
context:
space:
mode:
authorXavier Claessens <xavier.claessens@collabora.com>2020-08-07 10:06:33 -0400
committerXavier Claessens <xclaesse@gmail.com>2020-09-10 11:39:30 -0400
commit98d445a0708e56a511fb91c6189dea97b0a57d43 (patch)
tree390a72c98aafc2c69b16956e1360cdfdc0dfc553 /mesonbuild/msubprojects.py
parent3d443d84bdfd4987dbe299ac3b5fad591d01bced (diff)
downloadmeson-98d445a0708e56a511fb91c6189dea97b0a57d43.zip
meson-98d445a0708e56a511fb91c6189dea97b0a57d43.tar.gz
meson-98d445a0708e56a511fb91c6189dea97b0a57d43.tar.bz2
msubprojects: Support git subprojects with no wrap file
User could have cloned manually a subproject.
Diffstat (limited to 'mesonbuild/msubprojects.py')
-rwxr-xr-xmesonbuild/msubprojects.py7
1 files changed, 7 insertions, 0 deletions
diff --git a/mesonbuild/msubprojects.py b/mesonbuild/msubprojects.py
index 4575181..f1cc515 100755
--- a/mesonbuild/msubprojects.py
+++ b/mesonbuild/msubprojects.py
@@ -53,6 +53,10 @@ def update_git(wrap, repo_dir, options):
mlog.log(' -> Not used.')
return
revision = wrap.get('revision')
+ if not revision:
+ # It could be a detached git submodule for example.
+ mlog.log(' -> No revision specified.')
+ return
branch = git_output(['branch', '--show-current'], repo_dir).strip()
if branch == '':
try:
@@ -145,6 +149,9 @@ def checkout(wrap, repo_dir, options):
if wrap.type != 'git' or not os.path.isdir(repo_dir):
return
branch_name = options.branch_name if options.branch_name else wrap.get('revision')
+ if not branch_name:
+ # It could be a detached git submodule for example.
+ return
cmd = ['checkout', branch_name, '--']
if options.b:
cmd.insert(1, '-b')