diff --git a/lib/public/TextProcessing/IProvider.php b/lib/public/TextProcessing/IProvider.php index 6132e60b49371..fc57add183540 100644 --- a/lib/public/TextProcessing/IProvider.php +++ b/lib/public/TextProcessing/IProvider.php @@ -31,7 +31,7 @@ /** * This is the interface that is implemented by apps that * implement a text processing provider - * @template T of ITaskType + * @psalm-template-covariant T of ITaskType * @since 27.1.0 */ interface IProvider { diff --git a/lib/public/TextProcessing/Task.php b/lib/public/TextProcessing/Task.php index 446e414cb045c..9790cfdaebf89 100644 --- a/lib/public/TextProcessing/Task.php +++ b/lib/public/TextProcessing/Task.php @@ -28,9 +28,7 @@ /** * This is a text processing task * @since 27.1.0 - * @psalm-template T of ITaskType - * @psalm-template S as class-string - * @psalm-template P as IProvider + * @psalm-template-covariant T of ITaskType */ final class Task implements \JsonSerializable { protected ?int $id = null; @@ -73,7 +71,7 @@ final class Task implements \JsonSerializable { protected int $status = self::STATUS_UNKNOWN; /** - * @psalm-param S $type + * @psalm-param class-string $type * @param string $type * @param string $input * @param string $appId @@ -91,7 +89,7 @@ final public function __construct( } /** - * @psalm-param P $provider + * @psalm-param IProvider $provider * @param IProvider $provider * @return string * @since 27.1.0 @@ -105,7 +103,7 @@ public function visitProvider(IProvider $provider): string { } /** - * @psalm-param P $provider + * @psalm-param IProvider $provider * @param IProvider $provider * @return bool * @since 27.1.0 @@ -115,7 +113,7 @@ public function canUseProvider(IProvider $provider): bool { } /** - * @psalm-return S + * @psalm-return class-string * @since 27.1.0 */ final public function getType(): string { @@ -203,7 +201,7 @@ final public function getUserId(): ?string { } /** - * @psalm-return array{id: ?int, type: S, status: 0|1|2|3|4, userId: ?string, appId: string, input: string, output: ?string, identifier: string} + * @psalm-return array{id: ?int, type: class-string, status: 0|1|2|3|4, userId: ?string, appId: string, input: string, output: ?string, identifier: string} * @since 27.1.0 */ public function jsonSerialize(): array {