2018-02-22 08:08:29 -08:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
import os
|
|
|
|
import re
|
|
|
|
import sys
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
skip = set([
|
|
|
|
'test/sanity/code-smell/%s' % os.path.basename(__file__),
|
|
|
|
# digital_ocean is checking for six because dopy doesn't specify the
|
|
|
|
# requirement on six so it needs to try importing six to give the correct error message
|
|
|
|
'lib/ansible/modules/cloud/digital_ocean/digital_ocean.py',
|
|
|
|
])
|
|
|
|
|
2018-02-26 23:32:19 -08:00
|
|
|
for path in sys.argv[1:] or sys.stdin.read().splitlines():
|
2018-02-22 08:08:29 -08:00
|
|
|
if path in skip:
|
|
|
|
continue
|
|
|
|
|
|
|
|
if path.startswith('test/sanity/pylint/plugins/'):
|
|
|
|
continue
|
|
|
|
|
|
|
|
with open(path, 'r') as path_fd:
|
|
|
|
for line, text in enumerate(path_fd.readlines()):
|
|
|
|
match = re.search(r'((^\s*import\s+six\b)|(^\s*from\s+six\b))', text)
|
|
|
|
|
|
|
|
if match:
|
|
|
|
print('%s:%d:%d: use `ansible.module_utils.six` instead of `six`' % (
|
|
|
|
path, line + 1, match.start(1) + 1))
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|