1
0
forked from VimPlug/jedi

Start fixing some of the problems with new typeshed

This commit is contained in:
Dave Halter
2026-04-28 01:41:40 +02:00
parent 2455414d1d
commit ff581e8403
6 changed files with 17 additions and 45 deletions
+1 -2
View File
@@ -779,8 +779,7 @@ def preload_module(*modules):
:param modules: different module names, list of string. :param modules: different module names, list of string.
""" """
for m in modules: for m in modules:
s = "import %s as x; x." % m Script(f"import {m}").infer()
Script(s).complete(1, len(s))
def set_debug_function(func_cb=debug.print_to_stdout, warnings=True, def set_debug_function(func_cb=debug.print_to_stdout, warnings=True,
+3 -2
View File
@@ -14,8 +14,9 @@ def builtin_from_name(inference_state, string):
else: else:
filter_ = next(typing_builtins_module.get_filters()) filter_ = next(typing_builtins_module.get_filters())
name, = filter_.get(string) name, = filter_.get(string)
value, = name.infer() # Most of the time there is only symbol, but sometimes there are different
return value # sys.version_infos, where there are multiple ones, just use the first one.
return next(iter(name.infer()))
class ExactValue(LazyValueWrapper): class ExactValue(LazyValueWrapper):
+2 -13
View File
@@ -58,19 +58,8 @@ def _create_stub_map(directory_path_info):
def _get_typeshed_directories(version_info): def _get_typeshed_directories(version_info):
check_version_list = ['2and3', '3'] yield PathInfo(str(TYPESHED_PATH.joinpath("stdlib")), False)
for base in ['stdlib', 'third_party']: yield PathInfo(str(TYPESHED_PATH.joinpath("stubs")), True)
base_path = TYPESHED_PATH.joinpath(base)
base_list = os.listdir(base_path)
for base_list_entry in base_list:
match = re.match(r'(\d+)\.(\d+)$', base_list_entry)
if match is not None:
if match.group(1) == '3' and int(match.group(2)) <= version_info.minor:
check_version_list.append(base_list_entry)
for check_version in check_version_list:
is_third_party = base != 'stdlib'
yield PathInfo(str(base_path.joinpath(check_version)), is_third_party)
_version_cache: Dict[Tuple[int, int], Mapping[str, PathInfo]] = {} _version_cache: Dict[Tuple[int, int], Mapping[str, PathInfo]] = {}
+1 -1
View File
@@ -19,7 +19,7 @@ def load_proper_stub_module(inference_state, grammar, file_io, import_names, mod
# /[...]/stdlib/3/os/__init__.pyi -> stdlib/3/os/__init__ # /[...]/stdlib/3/os/__init__.pyi -> stdlib/3/os/__init__
rest = relative_path.with_suffix('') rest = relative_path.with_suffix('')
# Remove the stdlib/3 or third_party/3.6 part # Remove the stdlib/3 or third_party/3.6 part
import_names = rest.parts[2:] import_names = rest.parts[1:]
if rest.name == '__init__': if rest.name == '__init__':
import_names = import_names[:-1] import_names = import_names[:-1]
+1 -1
View File
@@ -173,7 +173,7 @@ def test_get_line_code(Script):
return Script(source).complete(line=line)[0].get_line_code(**kwargs).replace('\r', '') return Script(source).complete(line=line)[0].get_line_code(**kwargs).replace('\r', '')
# On builtin # On builtin
assert get_line_code('abs') == 'def abs(__x: SupportsAbs[_T]) -> _T: ...\n' assert get_line_code('abs') == 'def abs(x: SupportsAbs[_T], /) -> _T: ...\n'
# On custom code # On custom code
first_line = 'def foo():\n' first_line = 'def foo():\n'
@@ -1,35 +1,18 @@
import os import os
import pytest import pytest
from parso.utils import PythonVersionInfo
from jedi.inference.gradual import typeshed from jedi.inference.gradual import typeshed
from jedi.inference.value import TreeInstance, BoundMethod, FunctionValue, \ from jedi.inference.value import TreeInstance, BoundMethod, FunctionValue, \
MethodValue, ClassValue MethodValue, ClassValue
from jedi.inference.names import StubName from jedi.inference.names import StubName
TYPESHED_PYTHON3 = os.path.join(typeshed.TYPESHED_PATH, 'stdlib', '3') TYPESHED_PYTHON = os.path.join(typeshed.TYPESHED_PATH, 'stdlib')
def test_get_typeshed_directories():
def get_dirs(version_info):
return {
p.path.replace(str(typeshed.TYPESHED_PATH), '').lstrip(os.path.sep)
for p in typeshed._get_typeshed_directories(version_info)
}
def transform(set_):
return {x.replace('/', os.path.sep) for x in set_}
dirs = get_dirs(PythonVersionInfo(3, 7))
assert dirs == transform({'stdlib/2and3', 'stdlib/3', 'stdlib/3.7',
'third_party/2and3',
'third_party/3', 'third_party/3.7'})
def test_get_stub_files(): def test_get_stub_files():
map_ = typeshed._create_stub_map(typeshed.PathInfo(TYPESHED_PYTHON3, is_third_party=False)) map_ = typeshed._create_stub_map(typeshed.PathInfo(TYPESHED_PYTHON, is_third_party=False))
assert map_['functools'].path == os.path.join(TYPESHED_PYTHON3, 'functools.pyi') assert map_['functools'].path == os.path.join(TYPESHED_PYTHON, 'functools.pyi')
def test_function(Script, environment): def test_function(Script, environment):
@@ -142,7 +125,7 @@ def test_type_var(Script):
def test_math_is_stub(Script, code, full_name): def test_math_is_stub(Script, code, full_name):
s = Script(code) s = Script(code)
cos, = s.infer() cos, = s.infer()
wanted = ('typeshed', 'stdlib', '2and3', 'math.pyi') wanted = ('third_party', 'typeshed', 'stdlib', 'math.pyi')
assert cos.module_path.parts[-4:] == wanted assert cos.module_path.parts[-4:] == wanted
assert cos.is_stub() is True assert cos.is_stub() is True
assert cos.goto(only_stubs=True) == [cos] assert cos.goto(only_stubs=True) == [cos]
@@ -222,14 +205,14 @@ def test_goto_stubs_on_itself(Script, code, type_):
def test_module_exists_only_as_stub(Script): def test_module_exists_only_as_stub(Script):
try: try:
import redis # type: ignore[import-untyped] # noqa: F401 import six # type: ignore[import-untyped] # noqa: F401
except ImportError: except ImportError:
pass pass
else: else:
pytest.skip('redis is already installed, it should only exist as a stub for this test') pytest.skip('six is already installed, it should only exist as a stub for this test')
redis_path = os.path.join(typeshed.TYPESHED_PATH, 'third_party', '2and3', 'redis') six_path = os.path.join(typeshed.TYPESHED_PATH, 'stubs', 'six')
assert os.path.isdir(redis_path) assert os.path.isdir(six_path)
assert not Script('import redis').infer() assert not Script('import six').infer()
def test_django_exists_only_as_stub(Script): def test_django_exists_only_as_stub(Script):