diff options
author | Taylor Yu <catalyst@torproject.org> | 2020-02-14 11:02:16 -0600 |
---|---|---|
committer | Taylor Yu <catalyst@torproject.org> | 2020-02-14 11:02:16 -0600 |
commit | 55f088bb2998e70cb88e17ce21c3541966ae94ad (patch) | |
tree | 6a2e1a077770ffdbc6dc79fffbee86dd163cf362 /scripts/maint/checkManpageAlpha.py | |
parent | 98899f20ad22e97c03235cfe13ff1fe416a15509 (diff) | |
download | tor-55f088bb2998e70cb88e17ce21c3541966ae94ad.tar.gz tor-55f088bb2998e70cb88e17ce21c3541966ae94ad.zip |
Script to check sorting of manpage entries
Add a script to help check the alphabetical ordering of option names
in a manpage. Closes ticket 33339.
Diffstat (limited to 'scripts/maint/checkManpageAlpha.py')
-rwxr-xr-x | scripts/maint/checkManpageAlpha.py | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/scripts/maint/checkManpageAlpha.py b/scripts/maint/checkManpageAlpha.py new file mode 100755 index 0000000000..70421c2fd1 --- /dev/null +++ b/scripts/maint/checkManpageAlpha.py @@ -0,0 +1,72 @@ +#!/usr/bin/python + +import difflib +import re +import sys + +# Assume we only use the "== Section Name" section title syntax +sectionheader_re = re.compile(r'^==+\s(.*)\s*$') + +# Assume we only use the "[[ItemName]]" anchor syntax +anchor_re = re.compile(r'^\[\[([^]]+)\]\]') + +class Reader(object): + def __init__(self): + self.d = {} + # Initial state is to gather section headers + self.getline = self._getsec + self.section = None + + def _getsec(self, line): + """Read a section header + + Prepare to gather anchors from subsequent lines. Don't change + state if the line isn't a section header. + """ + m = sectionheader_re.match(line) + if not m: + return + self.anchors = anchors = [] + self.d[m.group(1)] = anchors + self.getline = self._getanchor + + def _getanchor(self, line): + """Read an anchor for an item definition + + Append the anchor names to the list of items in the current + section. + """ + m = anchor_re.match(line) + if not m: + return self._getsec(line) + self.anchors.append(m.group(1)) + + def diffsort(self, key): + """Unified diff of unsorted and sorted item lists + """ + # Append newlines because difflib works better with them + a = [s + '\n' for s in self.d[key]] + b = sorted(a, key=str.lower) + return difflib.unified_diff(a, b, fromfile=key+' unsorted', + tofile=key+' sorted') + +def main(): + """Diff unsorted and sorted lists of option names in a manpage + + Use the file named by the first argument, or standard input if + there is none. + """ + try: + fname = sys.argv[1] + f = open(fname, 'r') + except IndexError: + f = sys.stdin + + reader = Reader() + for line in f: + reader.getline(line) + for key in sorted(reader.d.keys(), key=str.lower): + sys.stdout.writelines(reader.diffsort(key)) + +if __name__ == '__main__': + main() |