Skip to content

Commit

Permalink
typing: update run_mypy and mypy.ini
Browse files Browse the repository at this point in the history
  • Loading branch information
mensinda committed Sep 8, 2020
1 parent ca1878f commit 5deb33b
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 76 deletions.
26 changes: 22 additions & 4 deletions .mypy.ini
Original file line number Diff line number Diff line change
@@ -1,5 +1,23 @@
[mypy]
strict_optional = False
show_error_context = False
show_column_numbers = True
ignore_missing_imports = True
strict_optional = False
show_error_context = False
show_column_numbers = True
ignore_missing_imports = True

follow_imports = skip
warn_redundant_casts = True
warn_unused_ignores = True
warn_return_any = True
# warn_unreachable = True
disallow_untyped_calls = True
disallow_untyped_defs = True
disallow_incomplete_defs = True
disallow_untyped_decorators = True
no_implicit_optional = True
strict_equality = True
check_untyped_defs = True
# disallow_any_expr = True
# disallow_any_decorated = True
# disallow_any_explicit = True
# disallow_any_generics = True
# disallow_subclassing_any = True
98 changes: 26 additions & 72 deletions run_mypy.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,79 +6,34 @@
from pathlib import Path
import typing as T

normal_modules = [
'mesonbuild/interpreterbase.py',
'mesonbuild/mtest.py',
'mesonbuild/minit.py',
'mesonbuild/mintro.py',
'mesonbuild/mparser.py',
'mesonbuild/msetup.py',
modules = [
# fully typed submodules
'mesonbuild/ast',
'mesonbuild/wrap',
'mesonbuild/scripts',
'tools',
'mesonbuild/modules/fs.py',
# 'mesonbuild/dependencies/base.py',
'mesonbuild/wrap',

# specific files
'mesonbuild/arglist.py',
# 'mesonbuild/compilers/mixins/intel.py',
'mesonbuild/dependencies/boost.py',
'mesonbuild/dependencies/mpi.py',
'mesonbuild/dependencies/hdf5.py',
'mesonbuild/compilers/mixins/intel.py',
'mesonbuild/mlog.py',
'mesonbuild/mcompile.py',
'mesonbuild/mesonlib.py',
'mesonbuild/arglist.py',
'mesonbuild/dependencies/mpi.py',
'mesonbuild/envconfig.py',
]

strict_modules = [
'mesonbuild/interpreterbase.py',
'mesonbuild/mtest.py',
'mesonbuild/minit.py',
'mesonbuild/mintro.py',
'mesonbuild/mparser.py',
'mesonbuild/msetup.py',
'mesonbuild/mcompile.py',
'mesonbuild/mesonlib.py',
'mesonbuild/minit.py',
'mesonbuild/mintro.py',
'mesonbuild/mlog.py',
'mesonbuild/ast',
'mesonbuild/wrap',
'mesonbuild/scripts',
'mesonbuild/modules/fs.py',
'mesonbuild/dependencies/boost.py',
'mesonbuild/dependencies/hdf5.py',
'mesonbuild/compilers/mixins/intel.py',
'mesonbuild/arglist.py',
'run_mypy.py',
'tools',
]
'mesonbuild/mparser.py',
'mesonbuild/msetup.py',
'mesonbuild/mtest.py',

normal_args = ['--follow-imports=skip']
strict_args = normal_args + [
'--warn-redundant-casts',
'--warn-unused-ignores',
'--warn-return-any',
# '--warn-unreachable',
'--disallow-untyped-calls',
'--disallow-untyped-defs',
'--disallow-incomplete-defs',
'--disallow-untyped-decorators',
'--no-implicit-optional',
'--strict-equality',
# '--disallow-any-expr',
# '--disallow-any-decorated',
# '--disallow-any-explicit',
# '--disallow-any-generics',
# '--disallow-subclassing-any',
'run_mypy.py',
'tools'
]

def run_mypy(opts: T.List[str], modules: T.List[str]) -> int:
root = Path(__file__).absolute().parent
p = subprocess.run(
[sys.executable, '-m', 'mypy'] + opts + modules,
cwd=root,
)
return p.returncode

def check_mypy() -> None:
try:
import mypy
Expand All @@ -87,24 +42,23 @@ def check_mypy() -> None:
sys.exit(1)

def main() -> int:
res = 0
check_mypy()

root = Path(__file__).absolute().parent
args = [] # type: T.List[str]

parser = argparse.ArgumentParser(description='Process some integers.')
parser.add_argument('-p', '--pretty', action='store_true', help='pretty print mypy errors')

args = parser.parse_args()
if args.pretty:
normal_args.append('--pretty')
strict_args.append('--pretty')
opts = parser.parse_args()
if opts.pretty:
args.append('--pretty')

print('Running normal mypy check...')
res += run_mypy(normal_args, normal_modules)

print('\n\nRunning struct mypy check...')
res += run_mypy(strict_args, strict_modules)

return res
p = subprocess.run(
[sys.executable, '-m', 'mypy'] + args + modules,
cwd=root,
)
return p.returncode

if __name__ == '__main__':
sys.exit(main())

0 comments on commit 5deb33b

Please sign in to comment.