From 9c35ed2eb71c8e9ea9e3e23a6c8995d0df289497 Mon Sep 17 00:00:00 2001 From: Daniil Gentili Date: Wed, 30 Nov 2022 17:33:58 +0100 Subject: [PATCH] Ignore non-existing classes during initial scan of intersection types --- src/Psalm/Type.php | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/src/Psalm/Type.php b/src/Psalm/Type.php index b00696b0b..40ab9c4ea 100644 --- a/src/Psalm/Type.php +++ b/src/Psalm/Type.php @@ -850,12 +850,16 @@ abstract class Type ) { /** @psalm-suppress TypeDoesNotContainType */ if ($type_1_atomic instanceof TNamedObject && $type_2_atomic instanceof TNamedObject) { - $first = $codebase->classlike_storage_provider->get($type_1_atomic->value); - $second = $codebase->classlike_storage_provider->get($type_2_atomic->value); - $first_is_class = !$first->is_interface && !$first->is_trait; - $second_is_class = !$second->is_interface && !$second->is_trait; - if ($first_is_class && $second_is_class) { - return $intersection_atomic; + try { + $first = $codebase->classlike_storage_provider->get($type_1_atomic->value); + $second = $codebase->classlike_storage_provider->get($type_2_atomic->value); + $first_is_class = !$first->is_interface && !$first->is_trait; + $second_is_class = !$second->is_interface && !$second->is_trait; + if ($first_is_class && $second_is_class) { + return $intersection_atomic; + } + } catch (InvalidArgumentException $e) { + // Ignore non-existing classes during initial scan } } if ($intersection_atomic === null && $wider_type === null) { @@ -914,7 +918,12 @@ abstract class Type if (!$type instanceof TNamedObject) { return false; } - $storage = $codebase->classlike_storage_provider->get($type->value); + try { + $storage = $codebase->classlike_storage_provider->get($type->value); + } catch (InvalidArgumentException $e) { + // Ignore non-existing classes during initial scan + return true; + } return !$storage->final; }