Releases: microsoft/pyright
Releases Β· microsoft/pyright
Published 1.1.372
Bug Fixes:
- Fixed bug that can result in incorrect evaluation of a traditional (pre-PEP 695) type alias the defines a union which is later used as the second argument to an
isinstance
orissubclass
call. - Fixed bug in type narrowing logic for sequence pattern matching when a "star" entry in the pattern captures a TypeVarTuple. The resulting type should be
Unknown
rather than the unpacked TypeVarTuple. - (from pylance) Fixed regression that broke CLI when used with poetry or other tools that depend on the working directory.
- Fixed a recent regression that results in a false positive when the fully-qualified form of
typing.Request
is used in an annotation expression. - Fixed a bug that results in false positive
reportInconsistentConstructor
errors if one or both of__init__
or__new__
are overloaded. - Fixed a bug that results in a false positive
reportOverlappingOverload
error in certain cases involvingParamSpec
andConcatenate
. - Fixed a bug that results in incorrect import resolution behaviors when a ".py" file and a directory have the same name, and the directory doesn't have a
__init__.py
file in it. In this case, the ".py" file should take precedence during imports. - Fixed inconsistent behavior when evaluating a binary expression with an
or
orand
operator when the LHS evaluates to a literalint
,str
,bytes
orbool
type. - Fixed bug that results in a false positive error under certain circumstances when a generator function with no type annotation contains a return value.
- Fixed bug that results in some circumstances in incorrect specialization of
type[T]
whenT
evaluates toAny
. - Fixed false positive error when using an overloaded
__init_subclass__
method under certain circumstances.
Enhancements:
- Added support for negative type narrowing (in the fall-through case) for a mapping pattern consisting of a single dictionary expand entry. This should match all mapping types, eliminating them in the fall-through case.
- Added support for class declarations within an enum class body -- both with and without
@member
and@nonmember
decorators. - Added "literal math" support for bitwise operators (left shift, right shift, logical or, logical and, logical xor, and invert).
- Improved the handling of bidirectional type inference for call expressions when the expected type comprises a union.
- Added "literal math" support for exponentiation operator.
- Improved performance of type analyzer an average of 12% by refactoring internal data structures and making key objects "monomorphic". This allows the V8 Javascript engine (used in node) to JIT more optimal code.
Behavior Changes:
- Changed union creation logic to retain (rather than elide) redundant literals in some cases. In particular, for type expressions that explicitly include literals along with their non-literal counterpart like
Literal[1] | int
. Retaining these redundant subtypes can be useful for language server features like completion suggestions. - Changed the type of the
__doc__
attribute for a module to always bestr | None
. Previously, pyright changed its declared type tostr
if a docstring was present in the module, but this is incorrect because it's a writable value and can be set toNone
. - Changed logic for explicit specialization to allow
Never
as a type argument for a value-constrained type parameter ifNever
is an explicit constraint.
Published 1.1.371
Bug Fixes:
- Fixed regression that results in a false positive when a traditional type alias (not using PEP 695 syntax) defines a union and is then used as a second argument to an
isinstance
orissubclass
call. - Fixed bug that results in a false positive error when an unpack operator is used in an unparenthesized tuple expression on the RHS of an augmented assignment operator on Python 3.9 and newer.
- Fixed bug that results in a false positive error when using a TypeVar with an upper bound of
type
as a base class in aclass
statement. - Fixed bug that results in false negative when a
list
orset
expression includes more than 64 elements and is being evaluated with a bidirectional inference context. - Fixed type evaluation of old-style (pre-PEP 695) type alias that aliases a generic class when it is used as a direct constructor call.
- Fixed bug that causes a false positive error when an
__init_subclass__
has overloads. - Bumped minimum engine version from 1.86 to 1.89 to match the recently-updated language client library requirements.
Behavior Changes:
- Changed the hard-coded type of the
__class__
symbol to beSelf@T
rather thanT
(whereT
is the enclosing class).
Enhancements:
- Added experimental support for multithreaded type checking in CLI. You can now specify
--threads
followed by an optional thread count. If no count is specified, pyright will use a value equal to the number of logical processors. Experimentation shows that this can speed up type checking by 2x to 3x for larger code bases. It has little or no effect (and possibly negative effects) for small code bases. - Improved detection of the use of variables used in type annotations.
- Improved type narrowing in the fall-through case for sequence patterns when the pattern includes a star pattern and the subject type is a tuple with an indeterminate entry.
- Improved handling of tuple expressions used in type expressions that involve specialization, such as
dict[()]
. - Updated typeshed stubs to the latest version.
- (From pylance) Improved security of python interpreter execution when determining the default python import resolution paths and python version.
Published 1.1.370
Bug Fixes:
- Fixed bug that resulted in a false negative when assigning to type
tuple[Never]
. - Fixed bug that results in incorrect type
isinstance
orissubclass
type narrowing when using a type variable with an upper bound that includes a promotion type. - Fixed recent regression that results in an assertion failure (and therefore a crash) when
type()
is called with dynamic base classes. - Fixed bug that results in a false positive when a protocol includes a method implementation that conditionally raises
NotImplementedError
. - Fixed bug that results in false positive
reportInconsistentOverload
andreportNoOverloadImplementation
errors when an overloaded decorator is applied to a non-overloaded function or method. - Fixed recent regression that results in false positive when a inner function with an inferred return type is a coroutine (async) and is referenced within the function body in which it's declared.
- (from Pylance) Fixed recent regression that results in diagnosticSeverityOverrides to be ignored if a pyproject.toml file is present, even if there is no
[tools.pyright]
section in it. - Fixed bug that results in incorrect type evaluation of a function that accepts a Callable[P, T] and is passed a class object whose constructor needs to be converted to a callable.
- Fixed bug that results in a spurious error when evaluating a quoted (forward reference) type expression that includes an index expression within a
TypeAlias
definition. - Fixed a bug in the type narrowing for the "x is " type guard pattern when
<class>
is a specific class T, as opposed to a variable of typetype[T]
. - Fixed bug that resulted in a false positive error when an abstract class is used for a
NewType
and the new type is constructed. - Fixed bug that results in the incorrect default value of a variadic type variable when the type argument is not provided. It should default to
*tuple[Any, ...]
, not*tuple[Any]
. - Fixed bug that results in a false negative when passing an extra keyword argument to a callable that is parameterized with a ParamSpec.
- Fixed bug that results in a false positive reportUntypedFunctionDecorator error under certain circumstances.
Enhancements:
- Updated typeshed stubs to the latest version.
- Improved analysis performance for complex code flow graphs by adding a cache for reachability.
- Implemented optimization in the protocol matching cache.
- Improved handling of special forms, including TypeAliasType instances, when used in value expressions.
Published 1.1.369
Behavior Changes:
- Improved consistency of unreachable code. Previously, unreachable code was not supported for
if
orelse
suites when the condition type was narrowed toNever
. - Changed hover provider output for type aliases to conform more closely with the new Python 3.12
type
syntax.
Enhancements:
- Added support for detecting mismatched property types in base classes used for multiple inheritance.
- Improved
reportUninitializedInstanceVariable
check to handle dataclass variables that are initialized implicitly by the synthesized__init__
method. - Added support for walrus (assignment) operator within set literal expressions if the python version is >= 3.10. The grammar was changed in 3.10 to support this.
Bug Fixes:
- Fixed recent regression in
reportUninitializedInstanceVariable
check relating toNamedTuple
instance variables. - Fixed bug that leads to a false negative when a subscript object used in an index expression supports
__index__
but the indexed object specifies that it requiresint
. - Fixed recent regression that results in a runtime assert (and therefore a crash) in certain circumstances when computing the MRO for a class.
- Fixed bug that results in an incorrect overload implementation diagnostic when using
tuple[()]
in overloads. - Improved diagnostic messages for type errors detected during
__set__
and__delete__
calls to a descriptor object. - Fixed bug that results in a false positive error when using a callback protocol with a function-scoped type variable.
- Fixed bug that incorrectly evaluates a constructor call to a constructor that infers a class-scoped ParamSpec when the passed function is generic.
- Fixed bug that leads to a spurious "unbound variable" diagnostic when a variable is assigned a value using a walrus operator and is later used in a
**
call argument. - Fixed bug that results in incorrect type narrowing in the negative (fall-through) case of a match expression when the subject expression is an unbounded tuple.
Published 1.1.368
Bug Fixes:
- Fixed a bug that causes
warnings.deprecated
not to work if the python version is 3.13. This was caused by recent changes to typeshed stubs. - Fixed bug that results in inconsistent diagnostics when surrounding an argument expression with parentheses.
- Fixed bug that causes a "bare"
type
(with no type argument) ortype[Any]
to be treated as a possible descriptor object. - Fixed regression that results in an internal assertion (and crash) related to TypeVar variance inference.
- Fixed a bug in the "type printer" (the component responsible for translating a type into its textual form) for type aliases defined using PEP 695 syntax.
- Fixed bug that resulted in the incorrect synthesis of
__dataclass_fields__
for named tuples. - (Contributed by @insync) Fixed
stubPath
's default value in configuration schema. - Fixed bug in pattern matching for
Callable()
in the negative (fall-through) case. - Fixed bug that results in unions consisting of different specialized forms of a generic TypedDict to "lose" all but one of these subtypes.
Behavior Changes:
- Changed inference behavior for generator functions with no reachable
yield
oryield from
statements. The "yield type" (the first type argument toGenerator
) is now inferred asNever
in this case rather thanNone
. - Changed the behavior of double underscored symbols that are part of a module's namespace when that module is not a stub or in a "py.typed" package. Such symbols are no longer ignored, although they are considered private.
- Changed the way that PEP 695 type aliases are displayed when hovering over a reference to the type alias. Previously, the symbol was displayed as
TypeAliasType
rather than the expanded type alias type.
Enhancements:
- Added support for
deprecated
objects that are instantiated prior to being used as a decorator. This allows for a factory usage pattern. - Added check for illegal use of
Protocol
type argument that is not a type parameter. The runtime generates an exception for this condition.
Published 1.1.367
Bug Fixes:
- Fixed bug that results in incorrect truthy/falsy type narrowing for an enum that overrides
__bool__
. - Fixed bug that results in a false positive when accessing a generic attribute in a base class from a subclass that explicitly specializes the generic type.
- Fixed bug that results in duplicate and (contradictory) diagnostic outputs in certain cases where
reveal_type
is used in a loop. - Fixed a bug that results in incorrect (local) type evaluation of an instance variable with a declared type when assigned within a loop that uses an augmented assignment.
- Fixed bug that causes
Final
annotation not to be honored when wrapped in anAnnotated
annotation. - Fixed bug that results in a false positive error under certain circumstances involving tuple type narrowing in a loop.
- Fixed bug that led to divergent behaviors between pyrightconfig.json and pyproject.toml configurations. Specifically, default exclude patterns were not added in the case of pyproject.toml. Thanks to @augustelalande for contributing to this fix.
- Fixed bug that results in parameter types being converted to
Any
when converting aNewType
or dataclass constructor to a callable.
Enhancements:
- Updated typeshed stubs to the latest version.
- Implemented provisional support for PEP 746, which provides consistency checks for metadata used in an
Annotated
annotation. - Added check for
except*
to enforce that exception class does not derive fromBaseExceptionGroup
. - Added the ability to override type checking configuration settings for each execution environment. This allows, for example, a test directory to use different settings than the directories that contain production code.
Behavior Changes:
- Added extra blank line to JSON output to assist with parsing when used in watch mode.
- Changed the import resolution order to better reflect runtime behavior and match a proposed change to the typing spec. In particular, stdlib typeshed stubs are now resolved prior to
site_packages
.
Published 1.1.366
Bug Fixes:
- Fixed bug that results in a false positive error under certain circumstances involving a call to a higher-order generic function with another function that involves a class with a contravariant type variable.
- Fixed bug that results in a confusing error message when stub generation fails.
- Fixed bug that results in false positive when evaluating the call to a generic function that involves a type variable used in both a covariant and contravariant (or invariant) position and both literal and non-literal types are involved.
- Fixed bug that results in a false negative when solving a type variable that involves an invariant context.
- Fixed a bug that can result in incorrect type inference for a subexpression that is part of an assignment expression if executed with an inference context (bidirectional type inference).
- Fixed bug in
x is E
type narrowing pattern whereE
is an enum literal andx
is a supertype ofE
likeobject
.
Behavior Changes:
- Changed behavior of constructor call evaluation when
__new__
evaluation results in type evaluation errors. Previously, pyright skipped the__init__
evaluation in this case. It now proceeds to evaluate__init__
, potentially generating redundant errors. - Removed support for inlined TypedDict annotations. This was an experimental feature that never gained enough support to make it into a PEP.
- Changed behavior of pyright to match the latest typing spec when it encounters an attribute with a type annotation within an
Enum
class body in a stub. These are now treated as non-member attributes rather than members. Typeshed stubs have been updated to conform to the new standard. - Added diagnostic check for an enum member with a type annotation. The typing spec says that this should be considered a typing error.
Enhancements:
- Updated typeshed stubs to the latest version.
Published 1.1.365
Bug Fixes:
- Fixed regression that results in the incorrect type evaluation for the
value
attribute of aStrEnum
orIntEnum
class. - Fixed a bug that results in incorrect type compatibility checks for a callable that uses
*args: *tuple[T, *tuple[S, ...]]
. - Fixed a bug that results in an unsolved TypeVar when calling
list(tuple())
. - Fixed bug that leads to inconsistent narrowing-on-assignment behavior when a
tuple
instance with unknown type arguments is assigned to a target symbol with a declaredtuple
type. - Fixed bug that results in a false negative when a
Final
class variable is assigned a value in the class body and reassigned a value in the__init__
method.
Behavior Changes:
- Changed tuple expression inference behavior to not preserve literal entry types if the tuple expression is embedded within another tuple, set, list, or dictionary expression.
- [Contribution by @ujan-r] Use typeshed version info for stdlib module list.
Enhancements:
- Improved diagnostic messages for parameter mismatch.
- Added support for configuration inheritance through an "extends" configuration option.
- Added support for custom ".toml" files specified via the
-p
option on the command line.
Published 1.1.364
Bug Fixes:
- Fixed bug that results in a false negative syntax error when a PEP-695 type alias uses a keyword as a name.
- Fixed a bug that leads to a false positive error when first argument to
super
call is an instance of a metaclass. - Fixed recent regression that results in a false positive when accessing an enum member from an instance of an enum class.
- Fixed bug that results in a false negative when determining if a callable type is compatible with another callable type and the first has a
*args
parameter and the second has a single positional+keyword parameter. - Fixed a bug in the code flow engine that results in incorrect type evaluation in certain cases involving codependent variables in a loop.
- Fixed a bug that results in incorrect type narrowing for a type guard function that uses
TypeIs[type[T]]
. - Fixed regression related to "converter" field parameter for dataclasses when the converter refers to a generic class constructor.
- Fixed a bug that results in a false negative when a generic function has a parameter with a generic type and a default argument value. This could lead to a typing hole when considering subtyping rules for callables.
- Fixed a bug in the dataclass "converter" support that resulted in an error if the converter is
tuple
. - Fixed regression that results in incorrect type evaluation for annotations that involve nested protocols (such as
P[P[T]]
). - Fixed a bug that resulted in an infinite loop when a function that uses an
*args: *Ts
parameter is passed as an argument to itself. - Fixed bug that leads to a false negative when calling a callback function that returns a callable with a generic parameter type.
Behavior Changes:
- Changed the handling of
Enum
subclasses that explicitly overridevalue
orname
to avoid using the special-case logic for computing these types. This is done regardless of whether the class uses a custom metaclass. - Changed support for dataclass "converter" field parameter to be off by default. The "enableExperimentalFeatures" must now be enabled to use this feature. If and when PEP 712 is approved, it will be moved out of experimental.
- Added support for using
Literal
and various other special forms in a value expression.
Enhancements:
- Added support for recent addendum to typing spec that provides a special case for dataclasses so
ClassVar
andFinal
can be used together to distinguish between a regularFinal
instance variable and aClassVar
that is alsoFinal
. - Updated typeshed stubs to the latest version.
- Improved type printer (the component that converts an internal type to textual format for diagnostic messages) so it better handles special forms like
Literal
or unions when used in a value expression.
Published 1.1.363
Bug Fixes:
- Updated manifest to reflect the correct default value for
reportInvalidTypeForm
. - Fixed bug that resulted in diagnostics associated with the
reportUnnecessaryTypeIgnoreComment
check to not include the error code. - Fixed bug that causes a false positive
reportPrivateUsage
error when a global or nonlocal binding is used within a class to access an outer-scoped variable. - Fixed bug that results in a false positive
reportUnnecessaryComparison
when a variable is used in a conditional expression and its type is a union that includes aCoroutine
and a non-coroutine. - Fixed false positive
deprecatedTypingAliases
deprecation forcollections.abc.AbstractSet
due to a recent change in typeshed stubs. - Fixed recent regression that results in
assert_type
failure when a class is parameterized by a ParamSpec with a default value. - Improved handling of constrained TypeVars when used with unary operators.
- Fixed bug that results in incorrect type narrowing for a tuple with determinate length when indexed with an out-of-bounds slice.
- Fixed bug that results in incorrect type narrowing for
isinstance
orissubclass
type guard when the filter is a generic class whose type parameter has a default value. - Fixed bug that results in incorrect type evaluation behavior within class body of an enum class when one enum member is used to define another enum member. This involved a significant rewrite of the logic involving enum symbol evaluation.
- Fixed a bug that results in a false positive error when a decorator is applied to a property.
- Fixed bug that resulted in false positive when evaluating a function call involving a TypeVarTuple under certain circumstances.
- Fixed a bug that results in incorrect type evaluation when a function parameterized with a TypeVarTuple is passed as an argument to another function parameterized with a TypeVarTuple.
Behavior Changes:
- Deferred execution of type annotations (PEP 649) did not make it into Python 3.13 and has been deferred (again) until Python 3.14. Changing pyright's logic accordingly.
- Changed the type evaluation for
type(Any)
ortype(x)
wherex
is a value of typeAny
orUnknown
. These now evaluate totype[Unknown]
. - Changed the TypeVar scoping behavior for TypeVars that appear only within a Callable subtype within a function's declared return type. Previously, pyright scoped these TypeVars to the Callable rather than the function. This was due to issue #4285. I'm reversing this decision because it's not spec-compliant, creates a bunch of unnecessary complexity, and results in buggy behavior.