summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNadeem Vawda <nadeem.vawda@gmail.com>2012-02-22 09:53:09 (GMT)
committerNadeem Vawda <nadeem.vawda@gmail.com>2012-02-22 09:53:09 (GMT)
commit6721149501a68ab52c7d1f83300ecd6d5656cbb3 (patch)
tree7f02992acd2eefbbf8bb2c0f4c46cab397f93e4f
parente7ad4190586a8a76d90ad7501bbbb5b3f011da5a (diff)
parent9f64f731933bfebf6767a42a0ae75503c1936454 (diff)
downloadcpython-6721149501a68ab52c7d1f83300ecd6d5656cbb3.zip
cpython-6721149501a68ab52c7d1f83300ecd6d5656cbb3.tar.gz
cpython-6721149501a68ab52c7d1f83300ecd6d5656cbb3.tar.bz2
Merge: #14053: Fix "make patchcheck" to work with MQ.
Patch by Francisco Martín Brugué
-rw-r--r--Misc/NEWS3
-rwxr-xr-xTools/scripts/patchcheck.py12
2 files changed, 15 insertions, 0 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index 389b6ab..e102404 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -1990,6 +1990,9 @@ IDLE
Tools/Demos
-----------
+- Issue #14053: patchcheck.py ("make patchcheck") now works with MQ patches.
+ Patch by Francisco Martín Brugué.
+
- Issue #13930: 2to3 is now able to write its converted output files to another
directory tree as well as copying unchanged files and altering the file
suffix. See its new -o, -W and --add-suffix options. This makes it more
diff --git a/Tools/scripts/patchcheck.py b/Tools/scripts/patchcheck.py
index 3e0155f..380574a 100755
--- a/Tools/scripts/patchcheck.py
+++ b/Tools/scripts/patchcheck.py
@@ -36,6 +36,16 @@ def status(message, modal=False, info=None):
return decorated_fxn
+def mq_patches_applied():
+ """Check if there are any applied MQ patches."""
+ cmd = 'hg qapplied'
+ with subprocess.Popen(cmd.split(),
+ stdout=subprocess.PIPE,
+ stderr=subprocess.PIPE) as st:
+ bstdout, _ = st.communicate()
+ return st.returncode == 0 and bstdout
+
+
@status("Getting the list of files that have been added/changed",
info=lambda x: n_files_str(len(x)))
def changed_files():
@@ -44,6 +54,8 @@ def changed_files():
sys.exit('need a checkout to get modified files')
cmd = 'hg status --added --modified --no-status'
+ if mq_patches_applied():
+ cmd += ' --rev qparent'
with subprocess.Popen(cmd.split(), stdout=subprocess.PIPE) as st:
return [x.decode().rstrip() for x in st.stdout]