ClassMethodsParametersCountCheck
class ClassMethodsParametersCountCheck extends AbstractMethodFlagCheck (View source)
Validates that the number of parameters in stub methods matches reflection.
For each class identified by $entityId the validator:
- Iterates all methods reported by reflection for the class.
- Looks up each method in the version-filtered stub hierarchy (parent classes and interfaces), stripping PS_UNRESERVEPREFIX where needed.
- If the stub method is not found it is silently skipped — existence is ClassMethodsExistCheck's responsibility.
- When both sides are found, the stub parameter list is filtered by version
(PhpStormStubsElementAvailable
from/to→ sinceVersion/removedVersion) and the resulting count is compared with the reflection count.
Parameter version filtering uses inclusive boundaries for removedVersion (<=),
consistent with how PhpStormStubsElementAvailable to is interpreted elsewhere
(e.g. to: '7.1' means the parameter is still available in PHP 7.1).
Parameters are deduplicated by name after version filtering. When a version-bounded
placeholder and a variadic share the same name (e.g. a to: '7.4' placeholder $vars
followed by ...$vars), they represent a single mandatory variadic parameter and are
counted once.
Known problems are supported at two granularities:
- class-level: EntityType::CLASS_TYPE + classId + 'ParametersCountCheck' → skips all parameter-count checks for the class.
- method-level: EntityType::METHOD + '\ClassName::methodName' + 'ParametersCountCheck' → skips only that specific mismatch.
Properties
| protected ReflectionProviderInterface | $reflectionProvider | from AbstractReflectionCheck | |
| protected KnownProblemsRegistry | $knownProblemsRegistry | from AbstractReflectionCheck | |
| protected EntityLookupService | $entityLookup | from AbstractClassCheck | |
| protected MethodCollectionService | $methodCollection | from AbstractClassCheck | |
| protected EntityTypeConfig|null | $entityTypeConfig | from AbstractClassCheck |
Methods
No description
Records a skipped-success result if a known problem covers this entity, and returns true.
Look up an entity by ID, dispatching to the right lookup method based on config.
Collect version-filtered methods, dispatching based on config.
Collect version-filtered properties, dispatching based on config.
No description
Compare a flag on the reflection and stub method.
Details
__construct(ReflectionProviderInterface|null $reflectionProvider = null, KnownProblemsRegistry|null $knownProblemsRegistry = null, EntityLookupService|null $entityLookup = null, MethodCollectionService|null $methodCollection = null, EntityTypeConfig|null $entityTypeConfig = null)
No description
protected bool
skipWithKnownProblem(CheckResultSet $results, string $entityType, string $entityId, string $checkName, string $phpVersion)
Records a skipped-success result if a known problem covers this entity, and returns true.
Returns false if validation should proceed normally.
protected PHPClassLikeObject|null
lookupEntityById(StubDataQueryInterface $storage, string $entityId)
Look up an entity by ID, dispatching to the right lookup method based on config.
Defaults to class lookup when no config is set.
protected array
collectEntityMethodsByConfig(PHPClassLikeObject $entity, string $phpVersion)
Collect version-filtered methods, dispatching based on config.
Defaults to class hierarchy traversal when no config is set.
protected array
collectEntityPropertiesByConfig(PHPClassLikeObject $entity, string $phpVersion)
Collect version-filtered properties, dispatching based on config.
Only classes have properties; returns empty array for enum/interface.
protected string
getEntityLabel()
No description
protected string
getEntityType()
No description
protected string
getConstantEntityType()
No description
protected PHPClass|null
findClassById(StubDataQueryInterface $storage, string $entityId)
No description
protected PHPEnum|null
findEnumById(StubDataQueryInterface $storage, string $entityId)
No description
protected PHPInterface|null
findInterfaceById(StubDataQueryInterface $storage, string $entityId)
No description
protected string
getCheckName()
No description
protected string|null
describeMismatch(string $methodEntityId, mixed $reflMethod, PHPMethod $stubMethod, string $phpVersion)
Compare a flag on the reflection and stub method.
Return a descriptive failure message if there is a mismatch, or null if they match.
bool
supports(string $phpVersion)
No description
CheckResultSet
run(StubDataQueryInterface $stubs, string $entityId, string $phpVersion)
No description