PHPStan Error Resolver

VerifiedCaution

Automatically resolves PHPStan errors by analyzing and fixing type issues. Loops until zero errors or stagnation.

Sby Skills Guide Bot
DevelopmentIntermediate
406/2/2026
Claude Code
#phpstan#static-analysis#php#error-resolution#code-quality

Recommended for

Our review

Automatically resolves PHPStan errors by analyzing and fixing type issues iteratively.

Strengths

  • Reduces PHPStan errors to zero or stagnation without manual intervention
  • Processes errors in batches of 5 per file for targeted fixes
  • Generates a detailed report with success rate and iteration count

Limitations

  • Requires a valid PHPStan configuration and proper PHP environment
  • Limited to a maximum of 10 iterations, which may be insufficient for large codebases
  • Relies on the @phpstan-error-resolver agent, inheriting its limitations
When to use it

Use this skill when you want to clean up a large number of PHPStan type errors in a PHP project quickly.

When not to use it

Avoid using it if you haven't set up PHPStan properly or if you prefer manual review of type corrections.

Security analysis

Caution
Quality score85/100

The skill employs Bash to run PHPStan and Edit to modify source files automatically. While there is no malicious payload or exfiltration intent, the combination of powerful tools and unattended file editing poses a moderate risk of unintended code damage.

Findings
  • Uses Bash and Edit tools for automated code modifications without explicit safeguards against destructive edits.
  • Automated code changes could inadvertently introduce bugs or vulnerabilities if the agent makes mistakes.

Examples

Run PHPStan error resolver
/qa:phpstan
Fix all PHPStan errors in the project
Run the PHPStan error resolver skill to fix all type errors in this project.

name: phpstan-resolver description: > Résout automatiquement les erreurs PHPStan en analysant et corrigeant les problèmes de types. Boucle jusqu'à zéro erreur ou stagnation. allowed-tools: [Task, Bash, Read, Edit, Grep, Glob] model: claude-opus-4-1-20250805

PHPStan Error Resolver Skill

Instructions à Exécuter

IMPORTANT : Exécute ce workflow étape par étape :

Usage

/qa:phpstan

Configuration

PHPSTAN_BIN="./vendor/bin/phpstan"
PHPSTAN_CONFIG="phpstan.neon"  # ou phpstan.neon.dist
ERROR_BATCH_SIZE=5
MAX_ITERATIONS=10

Workflow

Initialisation

Créer les tâches du workflow :

Utiliser TaskCreate pour chaque phase :

TaskCreate #1: Vérifier environnement PHPStan
TaskCreate #2: Exécuter analyse initiale (--error-format=json)
TaskCreate #3: Grouper erreurs par fichier
TaskCreate #4: Boucle de résolution (max 10 itérations)
TaskCreate #5: Générer rapport final

Important :

  • Utiliser activeForm (ex: "Vérifiant environnement PHPStan", "Résolvant erreurs")
  • La tâche #4 peut prendre du temps (boucle jusqu'à 10 itérations)
  • Chaque tâche doit être marquée in_progress puis completed

Pattern d'exécution pour chaque étape :

  1. TaskUpdate → tâche en in_progress
  2. Exécuter l'étape
  3. TaskUpdate → tâche en completed

Spécial pour la boucle de résolution (tâche #4) :

  • Marquer en in_progress au début de la boucle
  • Ne marquer en completed qu'à la fin (0 erreur, stagnation, ou max itérations)
  • Le statut reste in_progress pendant toutes les itérations

Étapes

  1. Vérifier environnement PHPStan
  2. Exécuter analyse initiale (--error-format=json)
  3. Grouper erreurs par fichier
  4. Boucle de résolution :
    • Déléguer corrections à @phpstan-error-resolver
    • Re-exécuter PHPStan
    • Répéter jusqu'à 0 erreur ou stagnation
  5. Générer rapport final

Délégation

Utilise l'agent @phpstan-error-resolver pour les corrections :

  • Batch de 5 erreurs par fichier par itération
  • Maximum 10 itérations

Rapport

details:
  total_errors_initial: X
  total_errors_final: Y
  errors_fixed: Z
  success_rate: "X%"
  iterations: N

Task Management

Progression du workflow :

  • 5 tâches créées à l'initialisation
  • La tâche #4 (boucle) reste in_progress pendant toutes les itérations
  • Chaque tâche suit le pattern : in_progress → exécution → completed
  • Utiliser TaskList pour voir la progression (notamment pour la boucle longue)
  • Les tâches permettent à l'utilisateur de suivre la résolution progressive des erreurs

References

Error Handling

  • PHPStan non trouvé → ARRÊT
  • Config absente → ARRÊT
  • Stagnation → ARRÊT avec rapport
  • Max itérations → ARRÊT avec rapport
Related skills