mirror of
https://github.com/astral-sh/ruff.git
synced 2025-10-24 17:16:53 +00:00
[ty] Repurpose FunctionType.into_bound_method_type
to return BoundMethodType
(#19793)
Some checks are pending
CI / Determine changes (push) Waiting to run
CI / cargo fmt (push) Waiting to run
CI / cargo clippy (push) Blocked by required conditions
CI / cargo test (linux) (push) Blocked by required conditions
CI / cargo test (linux, release) (push) Blocked by required conditions
CI / cargo test (windows) (push) Blocked by required conditions
CI / cargo test (wasm) (push) Blocked by required conditions
CI / cargo build (release) (push) Waiting to run
CI / cargo build (msrv) (push) Blocked by required conditions
CI / cargo fuzz build (push) Blocked by required conditions
CI / fuzz parser (push) Blocked by required conditions
CI / test scripts (push) Blocked by required conditions
CI / ecosystem (push) Blocked by required conditions
CI / Fuzz for new ty panics (push) Blocked by required conditions
CI / cargo shear (push) Blocked by required conditions
CI / python package (push) Waiting to run
CI / pre-commit (push) Waiting to run
CI / mkdocs (push) Waiting to run
CI / formatter instabilities and black similarity (push) Blocked by required conditions
CI / test ruff-lsp (push) Blocked by required conditions
CI / check playground (push) Blocked by required conditions
CI / benchmarks-instrumented (push) Blocked by required conditions
CI / benchmarks-walltime (push) Blocked by required conditions
[ty Playground] Release / publish (push) Waiting to run
Some checks are pending
CI / Determine changes (push) Waiting to run
CI / cargo fmt (push) Waiting to run
CI / cargo clippy (push) Blocked by required conditions
CI / cargo test (linux) (push) Blocked by required conditions
CI / cargo test (linux, release) (push) Blocked by required conditions
CI / cargo test (windows) (push) Blocked by required conditions
CI / cargo test (wasm) (push) Blocked by required conditions
CI / cargo build (release) (push) Waiting to run
CI / cargo build (msrv) (push) Blocked by required conditions
CI / cargo fuzz build (push) Blocked by required conditions
CI / fuzz parser (push) Blocked by required conditions
CI / test scripts (push) Blocked by required conditions
CI / ecosystem (push) Blocked by required conditions
CI / Fuzz for new ty panics (push) Blocked by required conditions
CI / cargo shear (push) Blocked by required conditions
CI / python package (push) Waiting to run
CI / pre-commit (push) Waiting to run
CI / mkdocs (push) Waiting to run
CI / formatter instabilities and black similarity (push) Blocked by required conditions
CI / test ruff-lsp (push) Blocked by required conditions
CI / check playground (push) Blocked by required conditions
CI / benchmarks-instrumented (push) Blocked by required conditions
CI / benchmarks-walltime (push) Blocked by required conditions
[ty Playground] Release / publish (push) Waiting to run
## Summary As per our naming scheme (at least for callable types) this should return a `BoundMethodType`, or be renamed, but it makes more sense to change the return type. I also ensure `ClassType.into_callable` returns a `Type::Callable` in the changed branch. Ideally we could return a `CallableType` from these `into_callable` functions (and rename to `into_callable_type` but because of unions we cannot do this.
This commit is contained in:
parent
98df62db79
commit
ef1802b94f
2 changed files with 8 additions and 4 deletions
|
@ -1044,7 +1044,11 @@ impl<'db> ClassType<'db> {
|
||||||
.place;
|
.place;
|
||||||
|
|
||||||
if let Place::Type(Type::FunctionLiteral(new_function), _) = new_function_symbol {
|
if let Place::Type(Type::FunctionLiteral(new_function), _) = new_function_symbol {
|
||||||
new_function.into_bound_method_type(db, self_ty)
|
Type::Callable(
|
||||||
|
new_function
|
||||||
|
.into_bound_method_type(db, self_ty)
|
||||||
|
.into_callable_type(db),
|
||||||
|
)
|
||||||
} else {
|
} else {
|
||||||
// Fallback if no `object.__new__` is found.
|
// Fallback if no `object.__new__` is found.
|
||||||
CallableType::single(
|
CallableType::single(
|
||||||
|
|
|
@ -800,13 +800,13 @@ impl<'db> FunctionType<'db> {
|
||||||
CallableType::new(db, self.signature(db), false)
|
CallableType::new(db, self.signature(db), false)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Convert the `FunctionType` into a [`Type::BoundMethod`].
|
/// Convert the `FunctionType` into a [`BoundMethodType`].
|
||||||
pub(crate) fn into_bound_method_type(
|
pub(crate) fn into_bound_method_type(
|
||||||
self,
|
self,
|
||||||
db: &'db dyn Db,
|
db: &'db dyn Db,
|
||||||
self_instance: Type<'db>,
|
self_instance: Type<'db>,
|
||||||
) -> Type<'db> {
|
) -> BoundMethodType<'db> {
|
||||||
Type::BoundMethod(BoundMethodType::new(db, self, self_instance))
|
BoundMethodType::new(db, self, self_instance)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn has_relation_to(
|
pub(crate) fn has_relation_to(
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue