[tor-commits] [tor/master] Short python script to lint the changes files

nickm at torproject.org nickm at torproject.org
Mon Dec 22 14:34:59 UTC 2014


commit 8b532a8c81577701c1af75d4641f7acb1ce5fc91
Author: Nick Mathewson <nickm at torproject.org>
Date:   Mon Dec 22 09:34:55 2014 -0500

    Short python script to lint the changes files
---
 scripts/maint/lintChanges.py |   46 ++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 46 insertions(+)

diff --git a/scripts/maint/lintChanges.py b/scripts/maint/lintChanges.py
new file mode 100755
index 0000000..43f2f21
--- /dev/null
+++ b/scripts/maint/lintChanges.py
@@ -0,0 +1,46 @@
+#!/usr/bin/python
+
+import sys
+import re
+
+
+
+def lintfile(fname):
+    have_warned = []
+    def warn(s):
+        if not have_warned:
+            have_warned.append(1)
+            print fname,":"
+        print "\t",s
+
+    m = re.search(r'(\d{3,})', fname)
+    if m:
+        bugnum = m.group(1)
+    else:
+        bugnum = None
+
+    with open(fname) as f:
+        contents = f.read()
+
+    if bugnum and bugnum not in contents:
+        warn("bug number %s does not appear"%bugnum)
+
+    lines = contents.split("\n")
+    isBug = ("bug" in lines[0] or "fix" in lines[0])
+
+    contents = " ".join(contents.split())
+
+    if isBug and not re.search(r'(\d+)', contents):
+        warn("bugfix does not mention a number")
+    elif isBug and not re.search(r'Fixes bug (\d+)', contents):
+        warn("bugfix does not say 'Fixes bug XXX'")
+
+    if re.search(r'[bB]ug (\d+)', contents) and not re.search(r'Bugfix on ', contents):
+        warn("bugfix does not say 'bugfix on X.Y.Z'")
+
+
+if __name__=='__main__':
+    for fname in sys.argv[1:]:
+        if fname.endswith("~"):
+            continue
+        lintfile(fname)



More information about the tor-commits mailing list