-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[red-knot] Add type inference for basic
for
loops (#13195)
- Loading branch information
1 parent
5728909
commit 46a4573
Showing
8 changed files
with
331 additions
and
131 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
use crate::module_name::ModuleName; | ||
use crate::module_resolver::resolve_module; | ||
use crate::semantic_index::global_scope; | ||
use crate::semantic_index::symbol::ScopeId; | ||
use crate::types::{global_symbol_ty, Type}; | ||
use crate::Db; | ||
|
||
/// Enumeration of various core stdlib modules, for which we have dedicated Salsa queries. | ||
#[derive(Debug, Clone, Copy, PartialEq, Eq)] | ||
enum CoreStdlibModule { | ||
Builtins, | ||
Types, | ||
Typeshed, | ||
} | ||
|
||
impl CoreStdlibModule { | ||
fn name(self) -> ModuleName { | ||
let module_name = match self { | ||
Self::Builtins => "builtins", | ||
Self::Types => "types", | ||
Self::Typeshed => "_typeshed", | ||
}; | ||
ModuleName::new_static(module_name) | ||
.unwrap_or_else(|| panic!("{module_name} should be a valid module name!")) | ||
} | ||
} | ||
|
||
/// Lookup the type of `symbol` in a given core module | ||
/// | ||
/// Returns `Unbound` if the given core module cannot be resolved for some reason | ||
fn core_module_symbol_ty<'db>( | ||
db: &'db dyn Db, | ||
core_module: CoreStdlibModule, | ||
symbol: &str, | ||
) -> Type<'db> { | ||
resolve_module(db, core_module.name()) | ||
.map(|module| global_symbol_ty(db, module.file(), symbol)) | ||
.unwrap_or(Type::Unbound) | ||
} | ||
|
||
/// Lookup the type of `symbol` in the builtins namespace. | ||
/// | ||
/// Returns `Unbound` if the `builtins` module isn't available for some reason. | ||
#[inline] | ||
pub(crate) fn builtins_symbol_ty<'db>(db: &'db dyn Db, symbol: &str) -> Type<'db> { | ||
core_module_symbol_ty(db, CoreStdlibModule::Builtins, symbol) | ||
} | ||
|
||
/// Lookup the type of `symbol` in the `types` module namespace. | ||
/// | ||
/// Returns `Unbound` if the `types` module isn't available for some reason. | ||
#[inline] | ||
pub(crate) fn types_symbol_ty<'db>(db: &'db dyn Db, symbol: &str) -> Type<'db> { | ||
core_module_symbol_ty(db, CoreStdlibModule::Types, symbol) | ||
} | ||
|
||
/// Lookup the type of `symbol` in the `_typeshed` module namespace. | ||
/// | ||
/// Returns `Unbound` if the `_typeshed` module isn't available for some reason. | ||
#[inline] | ||
pub(crate) fn typeshed_symbol_ty<'db>(db: &'db dyn Db, symbol: &str) -> Type<'db> { | ||
core_module_symbol_ty(db, CoreStdlibModule::Typeshed, symbol) | ||
} | ||
|
||
/// Get the scope of a core stdlib module. | ||
/// | ||
/// Can return `None` if a custom typeshed is used that is missing the core module in question. | ||
fn core_module_scope(db: &dyn Db, core_module: CoreStdlibModule) -> Option<ScopeId<'_>> { | ||
resolve_module(db, core_module.name()).map(|module| global_scope(db, module.file())) | ||
} | ||
|
||
/// Get the `builtins` module scope. | ||
/// | ||
/// Can return `None` if a custom typeshed is used that is missing `builtins.pyi`. | ||
pub(crate) fn builtins_module_scope(db: &dyn Db) -> Option<ScopeId<'_>> { | ||
core_module_scope(db, CoreStdlibModule::Builtins) | ||
} |
Oops, something went wrong.