[tor-commits] [stem/master] Renaming whitespace_check.py to check_whitespace.py
atagar at torproject.org
atagar at torproject.org
Mon Apr 16 16:23:02 UTC 2012
commit 1a2c7559e31fea6fba6856594f982f6f0959cd5d
Author: Damian Johnson <atagar at torproject.org>
Date: Mon Apr 16 09:22:25 2012 -0700
Renaming whitespace_check.py to check_whitespace.py
Previous naming was stupid, making it read better.
---
test/check_whitespace.py | 106 ++++++++++++++++++++++++++++++++++++++++++++++
test/whitespace_check.py | 106 ----------------------------------------------
2 files changed, 106 insertions(+), 106 deletions(-)
diff --git a/test/check_whitespace.py b/test/check_whitespace.py
new file mode 100644
index 0000000..e0419a5
--- /dev/null
+++ b/test/check_whitespace.py
@@ -0,0 +1,106 @@
+"""
+Performs a check that our python source code follows its whitespace conventions
+which are...
+
+* two space indentations
+* tabs are the root of all evil and should be shot on sight
+* no trailing whitespace unless the line is empty, in which case it should have
+ the same indentation as the surrounding code
+"""
+
+import re
+import os
+
+# if ran directly then run over everything one level up
+DEFAULT_TARGET = os.path.sep.join(__file__.split(os.path.sep)[:-1])
+
+def get_issues(base_path = DEFAULT_TARGET):
+ """
+ Checks python source code in the given directory for whitespace issues.
+
+ Arguments:
+ base_path (str) - directory to be iterated over
+
+ Returns:
+ dict of the form...
+ path => [(line_number, message)...]
+ """
+
+ # TODO: This does not check that block indentations are two spaces because
+ # differentiating source from string blocks ("""foo""") is more of a pita
+ # than I want to deal with right now.
+
+ issues = {}
+
+ for file_path in _get_python_files(base_path):
+ with open(file_path) as f: file_contents = f.read()
+ lines, file_issues, prev_indent = file_contents.splitlines(), [], 0
+
+ for i in xrange(len(lines)):
+ whitespace, content = re.match("^(\s*)(.*)$", lines[i]).groups()
+
+ if "\t" in whitespace:
+ file_issues.append((i + 1, "indentation has a tab"))
+ elif content != content.rstrip():
+ file_issues.append((i + 1, "line has trailing whitespace"))
+ elif content == '':
+ # empty line, check its indentation against the previous and next line
+ # with content
+
+ next_indent = 0
+
+ for k in xrange(i + 1, len(lines)):
+ future_whitespace, future_content = re.match("^(\s*)(.*)$", lines[k]).groups()
+
+ if future_content:
+ next_indent = len(future_whitespace)
+ break
+
+ if not len(whitespace) in (prev_indent, next_indent):
+ msg = "indentation should match surrounding content (%s spaces)"
+
+ if prev_indent == next_indent:
+ msg = msg % prev_indent
+ elif prev_indent < next_indent:
+ msg = msg % ("%i or %i" % (prev_indent, next_indent))
+ else:
+ msg = msg % ("%i or %i" % (next_indent, prev_indent))
+
+ file_issues.append((i + 1, msg))
+ else:
+ # we had content and it's fine, making a note of its indentation
+ prev_indent = len(whitespace)
+
+ if file_issues:
+ issues[file_path] = file_issues
+
+ return issues
+
+def _get_python_files(base_path):
+ """
+ Iterates over all of the python files within a directory.
+
+ Arguments:
+ base_path (str) - directory to be iterated over
+
+ Returns:
+ iterator that yields the absolute path for python source code
+ """
+
+ for root, _, files in os.walk(base_path, followlinks = True):
+ for filename in files:
+ if filename.endswith(".py"):
+ yield os.path.join(root, filename)
+
+if __name__ == '__main__':
+ issues = get_issues()
+
+ for file_path in issues:
+ print file_path
+
+ for line_number, msg in issues[file_path]:
+ line_count = "%-4s" % line_number
+ print " line %s %s" % (line_count, msg)
+
+ print
+
diff --git a/test/whitespace_check.py b/test/whitespace_check.py
deleted file mode 100644
index e0419a5..0000000
--- a/test/whitespace_check.py
+++ /dev/null
@@ -1,106 +0,0 @@
-"""
-Performs a check that our python source code follows its whitespace conventions
-which are...
-
-* two space indentations
-* tabs are the root of all evil and should be shot on sight
-* no trailing whitespace unless the line is empty, in which case it should have
- the same indentation as the surrounding code
-"""
-
-import re
-import os
-
-# if ran directly then run over everything one level up
-DEFAULT_TARGET = os.path.sep.join(__file__.split(os.path.sep)[:-1])
-
-def get_issues(base_path = DEFAULT_TARGET):
- """
- Checks python source code in the given directory for whitespace issues.
-
- Arguments:
- base_path (str) - directory to be iterated over
-
- Returns:
- dict of the form...
- path => [(line_number, message)...]
- """
-
- # TODO: This does not check that block indentations are two spaces because
- # differentiating source from string blocks ("""foo""") is more of a pita
- # than I want to deal with right now.
-
- issues = {}
-
- for file_path in _get_python_files(base_path):
- with open(file_path) as f: file_contents = f.read()
- lines, file_issues, prev_indent = file_contents.splitlines(), [], 0
-
- for i in xrange(len(lines)):
- whitespace, content = re.match("^(\s*)(.*)$", lines[i]).groups()
-
- if "\t" in whitespace:
- file_issues.append((i + 1, "indentation has a tab"))
- elif content != content.rstrip():
- file_issues.append((i + 1, "line has trailing whitespace"))
- elif content == '':
- # empty line, check its indentation against the previous and next line
- # with content
-
- next_indent = 0
-
- for k in xrange(i + 1, len(lines)):
- future_whitespace, future_content = re.match("^(\s*)(.*)$", lines[k]).groups()
-
- if future_content:
- next_indent = len(future_whitespace)
- break
-
- if not len(whitespace) in (prev_indent, next_indent):
- msg = "indentation should match surrounding content (%s spaces)"
-
- if prev_indent == next_indent:
- msg = msg % prev_indent
- elif prev_indent < next_indent:
- msg = msg % ("%i or %i" % (prev_indent, next_indent))
- else:
- msg = msg % ("%i or %i" % (next_indent, prev_indent))
-
- file_issues.append((i + 1, msg))
- else:
- # we had content and it's fine, making a note of its indentation
- prev_indent = len(whitespace)
-
- if file_issues:
- issues[file_path] = file_issues
-
- return issues
-
-def _get_python_files(base_path):
- """
- Iterates over all of the python files within a directory.
-
- Arguments:
- base_path (str) - directory to be iterated over
-
- Returns:
- iterator that yields the absolute path for python source code
- """
-
- for root, _, files in os.walk(base_path, followlinks = True):
- for filename in files:
- if filename.endswith(".py"):
- yield os.path.join(root, filename)
-
-if __name__ == '__main__':
- issues = get_issues()
-
- for file_path in issues:
- print file_path
-
- for line_number, msg in issues[file_path]:
- line_count = "%-4s" % line_number
- print " line %s %s" % (line_count, msg)
-
- print
-
More information about the tor-commits
mailing list