aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNirbheek Chauhan <nirbheek@centricular.com>2020-01-22 21:04:30 +0530
committerXavier Claessens <xclaesse@gmail.com>2020-01-22 17:29:38 -0500
commit712b2f08c7126863a68dc98c021fc40a4de462fd (patch)
tree35c916bbcb276fd7b4b7e6de2dd429afa02e2c1e
parentda486bfddcc2569dcd92ac26c86d8102824eb001 (diff)
downloadmeson-712b2f08c7126863a68dc98c021fc40a4de462fd.zip
meson-712b2f08c7126863a68dc98c021fc40a4de462fd.tar.gz
meson-712b2f08c7126863a68dc98c021fc40a4de462fd.tar.bz2
Move git helper out into mesonlib for reuse
Reuse the git helper for `meson wrap` and `meson subprojects` so we don't need to maintain the same git-colors-on-windows workarounds in multiple places.
-rw-r--r--mesonbuild/mesonlib.py14
-rwxr-xr-xmesonbuild/msubprojects.py10
-rw-r--r--mesonbuild/wrap/wrap.py16
3 files changed, 18 insertions, 22 deletions
diff --git a/mesonbuild/mesonlib.py b/mesonbuild/mesonlib.py
index 9ae7b76..85d883b 100644
--- a/mesonbuild/mesonlib.py
+++ b/mesonbuild/mesonlib.py
@@ -56,6 +56,20 @@ else:
python_command = [sys.executable]
meson_command = None
+GIT = shutil.which('git')
+def git(cmd: T.List[str], workingdir: str, **kwargs) -> subprocess.CompletedProcess:
+ pc = subprocess.run([GIT, '-C', workingdir] + cmd,
+ # Redirect stdin to DEVNULL otherwise git messes up the
+ # console and ANSI colors stop working on Windows.
+ stdin=subprocess.DEVNULL, **kwargs)
+ # Sometimes git calls git recursively, such as `git submodule update
+ # --recursive` which will be without the above workaround, so set the
+ # console mode again just in case.
+ if platform.system().lower() == 'windows':
+ mlog._windows_ansi()
+ return pc
+
+
def set_meson_command(mainfile):
global python_command
global meson_command
diff --git a/mesonbuild/msubprojects.py b/mesonbuild/msubprojects.py
index c69684f..d6f0715 100755
--- a/mesonbuild/msubprojects.py
+++ b/mesonbuild/msubprojects.py
@@ -2,7 +2,7 @@ import os, subprocess
import argparse
from . import mlog
-from .mesonlib import Popen_safe
+from .mesonlib import git, Popen_safe
from .wrap.wrap import API_ROOT, PackageDefinition, Resolver, WrapException
from .wrap import wraptool
@@ -40,12 +40,8 @@ def update_file(wrap, repo_dir, options):
' In that case, delete', mlog.bold(repo_dir), 'and run', mlog.bold('meson --reconfigure'))
def git_output(cmd, workingdir):
- return subprocess.check_output(['git', '-C', workingdir] + cmd,
- # Redirect stdin to DEVNULL otherwise git
- # messes up the console and ANSI colors stop
- # working on Windows.
- stdin=subprocess.DEVNULL,
- stderr=subprocess.STDOUT).decode()
+ return git(cmd, workingdir, check=True, universal_newlines=True,
+ stdout=subprocess.PIPE, stderr=subprocess.STDOUT).stdout
def git_show(repo_dir):
commit_message = git_output(['show', '--quiet', '--pretty=format:%h%n%d%n%s%n[%an]'], repo_dir)
diff --git a/mesonbuild/wrap/wrap.py b/mesonbuild/wrap/wrap.py
index 92e37de..e9b47a0 100644
--- a/mesonbuild/wrap/wrap.py
+++ b/mesonbuild/wrap/wrap.py
@@ -18,7 +18,6 @@ import urllib.request
import urllib.error
import urllib.parse
import os
-import platform
import hashlib
import shutil
import tempfile
@@ -29,7 +28,7 @@ import configparser
import typing as T
from . import WrapMode
-from ..mesonlib import ProgressBar, MesonException
+from ..mesonlib import git, GIT, ProgressBar, MesonException
if T.TYPE_CHECKING:
import http.client
@@ -44,23 +43,10 @@ except ImportError:
has_ssl = False
API_ROOT = 'http://wrapdb.mesonbuild.com/v1/'
-GIT = shutil.which('git')
REQ_TIMEOUT = 600.0
SSL_WARNING_PRINTED = False
WHITELIST_SUBDOMAIN = 'wrapdb.mesonbuild.com'
-def git(cmd: T.List[str], workingdir: str, **kwargs) -> subprocess.CompletedProcess:
- pc = subprocess.run([GIT, '-C', workingdir] + cmd,
- # Redirect stdin to DEVNULL otherwise git messes up the
- # console and ANSI colors stop working on Windows.
- stdin=subprocess.DEVNULL, **kwargs)
- # Sometimes git calls git recursively, such as `git submodule update
- # --recursive` which will be without the above workaround, so set the
- # console mode again just in case.
- if platform.system().lower() == 'windows':
- mlog._windows_ansi()
- return pc
-
def quiet_git(cmd: T.List[str], workingdir: str) -> T.Tuple[bool, str]:
if not GIT:
return False, 'Git program not found.'