7fb1a71a2c
* no-smart-quotes: Skip files by path in code-smell This is to ensure the generated docs do not trigger code-smell issues on contributor systems. * Implement feedback from review
47 lines
1.5 KiB
Python
Executable file
47 lines
1.5 KiB
Python
Executable file
#!/usr/bin/env python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
import os
|
|
import re
|
|
import sys
|
|
|
|
|
|
def main():
|
|
skip = set([
|
|
'docs/docsite/rst/dev_guide/testing/sanity/no-smart-quotes.rst',
|
|
'test/integration/targets/lookup_properties/lookup-8859-15.ini',
|
|
'test/integration/targets/template/files/encoding_1252_utf-8.expected',
|
|
'test/integration/targets/template/files/encoding_1252_windows-1252.expected',
|
|
'test/integration/targets/template/templates/encoding_1252.j2',
|
|
'test/integration/targets/unicode/unicode.yml',
|
|
'test/sanity/code-smell/%s' % os.path.basename(__file__),
|
|
])
|
|
|
|
prune = set([
|
|
'docs/docsite/_build/',
|
|
])
|
|
|
|
for path in sys.argv[1:] or sys.stdin.read().splitlines():
|
|
if path in skip:
|
|
continue
|
|
|
|
if any(path.startswith(p) for p in prune):
|
|
continue
|
|
|
|
with open(path, 'rb') as path_fd:
|
|
for line, text in enumerate(path_fd.readlines()):
|
|
try:
|
|
text = text.decode('utf-8')
|
|
except UnicodeDecodeError as ex:
|
|
print('%s:%d:%d: UnicodeDecodeError: %s' % (path, line + 1, ex.start + 1, ex))
|
|
continue
|
|
|
|
match = re.search(u'([‘’“”])', text)
|
|
|
|
if match:
|
|
print('%s:%d:%d: use ASCII quotes `\'` and `"` instead of Unicode quotes' % (
|
|
path, line + 1, match.start(1) + 1))
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|