mirror of
https://github.com/danog/psalm.git
synced 2024-11-30 04:39:00 +01:00
Only check interfaces for static matchup
This commit is contained in:
parent
d7089a87e2
commit
9e8c3b8c6e
@ -17,6 +17,7 @@ use Psalm\Issue\DeprecatedTrait;
|
||||
use Psalm\Issue\InaccessibleMethod;
|
||||
use Psalm\Issue\InternalClass;
|
||||
use Psalm\Issue\InvalidTemplateParam;
|
||||
use Psalm\Issue\MethodSignatureMismatch;
|
||||
use Psalm\Issue\MissingConstructor;
|
||||
use Psalm\Issue\MissingPropertyType;
|
||||
use Psalm\Issue\MissingTemplateParam;
|
||||
@ -426,6 +427,20 @@ class ClassAnalyzer extends ClassLikeAnalyzer
|
||||
return null;
|
||||
}
|
||||
|
||||
if ($interface_method_storage->is_static && !$implementer_method_storage->is_static) {
|
||||
if (IssueBuffer::accepts(
|
||||
new MethodSignatureMismatch(
|
||||
'Method ' . $implementer_method_storage->cased_name
|
||||
. ' should be static like '
|
||||
. $storage->name . '::' . $interface_method_storage->cased_name,
|
||||
$code_location
|
||||
),
|
||||
$implementer_method_storage->suppressed_issues
|
||||
)) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
MethodAnalyzer::compareMethods(
|
||||
$codebase,
|
||||
$implementer_classlike_storage ?: $storage,
|
||||
|
@ -519,19 +519,6 @@ class MethodAnalyzer extends FunctionLikeAnalyzer
|
||||
return null;
|
||||
}
|
||||
|
||||
if ($guide_method_storage->is_static && !$implementer_method_storage->is_static) {
|
||||
if (IssueBuffer::accepts(
|
||||
new MethodSignatureMismatch(
|
||||
'Method ' . $cased_implementer_method_id . ' should be static like '
|
||||
. $cased_guide_method_id,
|
||||
$code_location
|
||||
),
|
||||
$suppressed_issues
|
||||
)) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
if ($prevent_abstract_override
|
||||
&& !$guide_method_storage->abstract
|
||||
&& $implementer_method_storage->abstract
|
||||
|
Loading…
Reference in New Issue
Block a user