What's New - PHP Tools for Visual Studio (March 2023)#

We're happy to introduce updates to our PHP extension for Visual Studio! Version 1.72 introduces Inlay Hints, new Code Actions, improved code analysis, improved support for Doc Comments with extended syntax for Psalm and PHPStan type names and keywords, and more!
Inlay Hints#
Sometimes it is not clear what function arguments are used for. We are adding so-called inlay hints that annotate function parameters, inferred function return type, by-ref semantics to arguments, and expressions type.

Enable or disable Inlay Hints in Tools/Options, under Text Editor/PHP/Inlay Hints,
Code Actions#
Several quick refactorings through code actions have been added.

Assignments can be simplified with ??=, +=, *=, etc.

Transforming expressions to the new nullable object operator ?->.

Assignment using if conditions can be simplified.

And hard-to-read switch blocks can be simplified with the new match expression.
Better PHP 8.2 and PHP 8.1 Support#
enumandBackedEnumandUnitEnumimplicit interfacesreadonlyandenumparsed properly when used a part of the qualified name- updated integrated manual with the latest symbols and translations
- support for the new
Randomextension - support for the new PHP 8.2 core types
IntelliSense & Enums#
The PHP 8.1 enum objects implicitly implement UnitEnum and BackedEnum interfaces. The BackedEnum<TValue> interface is annotated with a template type argument so it can be used in Doc Comments with the backed type for better type analysis. E.g.:
function foo($e) {
return $e->value // -> string
}
enum MyEnum : string {
case A;
}
foo( MyEnum::A );
Doc Comments#
PHP Documentary Comments have been improved as well. In addition to more code diagnostics, the editor understands a wide range of Psalm and PHPStan type annotations. We've been working on recognizing commonly used type syntaxes in Doc Blocks; now supporting most of PHPStan, and other popular linting frameworks.

Image: Diagnostic showing missing variable name!
Types, including complex array shapes, generic types, template type annotations, unions, intersections, and callables; are all not properly colorized, occurrences highlighted, and code completion works (even inside < and > when specifying generic type arguments). Refactoring recognizes nested types within Doc Blocks, and the overall functionality of types within Doc Blocks is complete now.
Additionally, the triple dot syntax ... is now allowed within the @param tag, and the @param-out tag is recognized.
Improved Generics and PHPStan Compatibility#
- Supported the rest of
@template,@implements-*,@extends-*, and other notations. - Generic types support overall improvements, more supported scenarios, working with doctrine/collections, etc.
- Core PHP
Traversabletypes have been annotated with generic template type-arguments. foreachworks well with generic collections,Traversabletypes with generic annotations.
PHPStan Array Shape, callable, list, and More#
Since this release, the editor supports all the syntaxes for array shapes and callables. In addition, the type analysis handles specified PHPStan types accordingly.
PHPStan and Psalm array shapes specified in PHP Doc Comments are allowed, parsed, colorized, and used in code completion and type analysis.
Additionally, list and non-empty-list types are handled as well. Including their generic counterparts with < and > types specified.
All the callable syntaxes in PHP Doc Comments are supported now as well.
Array Shape Types Supported#
- doc comments allow using single-line structured array types in form of
array{ key: type, }
More Generic Annotations#
This update brings the standard types annotated with generic template types; this is especially helpful in Laravel and Symfony frameworks, where it provides type inferring for all the collections, iterables, Generator, DOMNodeList, etc.
This improves value inferred within foreach for all kinds of iterables.
New Diagnostics#
- Checks for use of
readonlyproperties. - Assignment to non-existing properties is checked.
- Check for use of an unknown attribute class.
- Check that class used within the
throwexpression is throwable. - Fixes many false-positive warnings!
- Newly, we report
interfacecontaining properties, which is not allowed in PHP. - Type analysis handles array type inferring, avoiding lots of falsy warnings.
- Newly, we report invalid types in
echoand concatenation expressions. - Type analysis for
array_map()is more precise, if the "map" functions can be determined.

- It is now possible to use PHPDoc right above the constructor property promotion, with just
@varannotation.

- Improved analysis of
define()withobject.
Other Editor & IntelliSense Improvements#
- Facades from traits are recognized.
- More precise type inference for some built-in functions.
- More precise analysis of
matcharms. - Completion of properties after
?->. - Updated integrated PHP manual.
- Go To Def prefers declaration in the same file. It avoids showing the unnecessary list of all functions.
- Comment/uncomment block (
`) instead of line comment (//`). - Lots of minor UI fixes and code analysis improvements.
- Tooltips show resolved generic types.
- Stub-only Phar packages (
.pharwith only the main stub, no file entries) are supported. - Blade files do not report falsy warnings.
- Generated doc comments (
/**) respectGeneratorfunctions. - Memory use optimizations.
- Overall type inferring improvements and fixes.
- PHPStan doc comment type syntaxes supported and improved.
- Avoids several falsy warnings.
integer,boolean,listtypes are handled properly in Doc Block.- Unused
useanalysis is fixed, so it handles type names specified in Doc Blocks. - Diagnostic and parameter completion for
session_set_cookie_params()works for both possible definitions. - Missing
Imagickconstants added. - Improves type inferring for generic types and various edge cases.