Skip to content

Commit

Permalink
autoflake.py: Add --ignore-init-module-imports (#42)
Browse files Browse the repository at this point in the history
When used, this new CLI argument will cause
autoflake to ignore unused imports when
checking any __init__.py files.

New tests have also been added to
accompany this new feature.

Closes #35
  • Loading branch information
CLiu13 authored and myint committed Dec 23, 2018
1 parent 9258ef1 commit 9fe7aae
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 6 deletions.
31 changes: 25 additions & 6 deletions autoflake.py
Original file line number Diff line number Diff line change
Expand Up @@ -331,7 +331,9 @@ def filter_code(source, additional_imports=None,
expand_star_imports=False,
remove_all_unused_imports=False,
remove_duplicate_keys=False,
remove_unused_variables=False):
remove_unused_variables=False,
ignore_init_module_imports=False,
):
"""Yield code with unused imports removed."""
imports = SAFE_IMPORTS
if additional_imports:
Expand All @@ -340,8 +342,11 @@ def filter_code(source, additional_imports=None,

messages = check(source)

marked_import_line_numbers = frozenset(
unused_import_line_numbers(messages))
if ignore_init_module_imports:
marked_import_line_numbers = frozenset()
else:
marked_import_line_numbers = frozenset(
unused_import_line_numbers(messages))
marked_unused_module = collections.defaultdict(lambda: [])
for line_number, module_name in unused_import_module_name(messages):
marked_unused_module[line_number].append(module_name)
Expand Down Expand Up @@ -589,7 +594,7 @@ def get_line_ending(line):

def fix_code(source, additional_imports=None, expand_star_imports=False,
remove_all_unused_imports=False, remove_duplicate_keys=False,
remove_unused_variables=False):
remove_unused_variables=False, ignore_init_module_imports=False):
"""Return code with all filtering run on it."""
if not source:
return source
Expand All @@ -608,7 +613,9 @@ def fix_code(source, additional_imports=None, expand_star_imports=False,
expand_star_imports=expand_star_imports,
remove_all_unused_imports=remove_all_unused_imports,
remove_duplicate_keys=remove_duplicate_keys,
remove_unused_variables=remove_unused_variables))))
remove_unused_variables=remove_unused_variables,
ignore_init_module_imports=ignore_init_module_imports,
))))

if filtered_source == source:
break
Expand All @@ -625,13 +632,22 @@ def fix_file(filename, args, standard_out):

original_source = source

isInitFile = os.path.basename(filename) == '__init__.py'

if args.ignore_init_module_imports and isInitFile:
ignore_init_module_imports = True
else:
ignore_init_module_imports = False

filtered_source = fix_code(
source,
additional_imports=args.imports.split(',') if args.imports else None,
expand_star_imports=args.expand_star_imports,
remove_all_unused_imports=args.remove_all_unused_imports,
remove_duplicate_keys=args.remove_duplicate_keys,
remove_unused_variables=args.remove_unused_variables)
remove_unused_variables=args.remove_unused_variables,
ignore_init_module_imports=ignore_init_module_imports,
)

if original_source != filtered_source:
if args.in_place:
Expand Down Expand Up @@ -791,6 +807,9 @@ def _main(argv, standard_out, standard_error):
parser.add_argument('--remove-all-unused-imports', action='store_true',
help='remove all unused imports (not just those from '
'the standard library)')
parser.add_argument('--ignore-init-module-imports', action='store_true',
help='exclude __init__.py when removing unused '
'imports')
parser.add_argument('--remove-duplicate-keys', action='store_true',
help='remove all duplicate keys in objects')
parser.add_argument('--remove-unused-variables', action='store_true',
Expand Down
35 changes: 35 additions & 0 deletions test_autoflake.py
Original file line number Diff line number Diff line change
Expand Up @@ -501,6 +501,41 @@ def foo():
"""
self.assertEqual(line, ''.join(autoflake.filter_code(line)))

def test_with_ignore_init_module_imports_flag(self):
# Need a temp directory in order to specify file name as __init__.py
temp_directory = tempfile.mkdtemp(dir='.')
temp_file = os.path.join(temp_directory, '__init__.py')
try:
with open(temp_file, 'w') as output:
output.write('import re\n')

p = subprocess.Popen(
list(AUTOFLAKE_COMMAND) +
['--ignore-init-module-imports', temp_file],
stdout=subprocess.PIPE)
result = p.communicate()[0].decode('utf-8')

self.assertNotIn('import re', result)
finally:
shutil.rmtree(temp_directory)

def test_without_ignore_init_module_imports_flag(self):
# Need a temp directory in order to specify file name as __init__.py
temp_directory = tempfile.mkdtemp(dir='.')
temp_file = os.path.join(temp_directory, '__init__.py')
try:
with open(temp_file, 'w') as output:
output.write('import re\n')

p = subprocess.Popen(
list(AUTOFLAKE_COMMAND) + [temp_file],
stdout=subprocess.PIPE)
result = p.communicate()[0].decode('utf-8')

self.assertIn('import re', result)
finally:
shutil.rmtree(temp_directory)

def test_fix_code(self):
self.assertEqual(
"""\
Expand Down

0 comments on commit 9fe7aae

Please sign in to comment.