46 lines
		
	
	
	
		
			880 B
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
	
		
			880 B
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php declare(strict_types=1);
 | |
| 
 | |
| namespace PhpParser\ErrorHandler;
 | |
| 
 | |
| use PhpParser\Error;
 | |
| use PhpParser\ErrorHandler;
 | |
| 
 | |
| /**
 | |
|  * Error handler that collects all errors into an array.
 | |
|  *
 | |
|  * This allows graceful handling of errors.
 | |
|  */
 | |
| class Collecting implements ErrorHandler
 | |
| {
 | |
|     /** @var Error[] Collected errors */
 | |
|     private $errors = [];
 | |
| 
 | |
|     public function handleError(Error $error) {
 | |
|         $this->errors[] = $error;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get collected errors.
 | |
|      *
 | |
|      * @return Error[]
 | |
|      */
 | |
|     public function getErrors() : array {
 | |
|         return $this->errors;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Check whether there are any errors.
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function hasErrors() : bool {
 | |
|         return !empty($this->errors);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Reset/clear collected errors.
 | |
|      */
 | |
|     public function clearErrors() {
 | |
|         $this->errors = [];
 | |
|     }
 | |
| }
 |