mirror of
				https://github.com/hauke68/Magallanes.git
				synced 2025-10-22 20:40:18 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			133 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /*
 | |
|  * This file is part of the Magallanes package.
 | |
| *
 | |
| * (c) Andrés Montañez <andres@andresmontanez.com>
 | |
| *
 | |
| * For the full copyright and license information, please view the LICENSE
 | |
| * file that was distributed with this source code.
 | |
| */
 | |
| 
 | |
| namespace Mage\Command;
 | |
| 
 | |
| use Mage\Config;
 | |
| 
 | |
| /**
 | |
|  * Abstract Class for a Magallanes Command
 | |
|  *
 | |
|  * @author Andrés Montañez <andres@andresmontanez.com>
 | |
|  */
 | |
| abstract class AbstractCommand
 | |
| {
 | |
|     /**
 | |
|      * Instance of the loaded Configuration.
 | |
|      *
 | |
|      * @var \Mage\Config
 | |
|      */
 | |
|     protected $config = null;
 | |
| 
 | |
|     private $helpMessage;
 | |
|     private $usageExamples = [];
 | |
|     private $syntaxMessage;
 | |
|     private $name;
 | |
| 
 | |
|     /**
 | |
|      * Runs the Command
 | |
|      * @return integer exit code
 | |
|      * @throws \Exception
 | |
|      */
 | |
|     abstract public function run();
 | |
| 
 | |
|     /**
 | |
|      * Sets the Loaded Configuration.
 | |
|      *
 | |
|      * @param Config $config
 | |
|      */
 | |
|     public function setConfig(Config $config)
 | |
|     {
 | |
|         $this->config = $config;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Gets the Loaded Configuration.
 | |
|      *
 | |
|      * @return Config
 | |
|      */
 | |
|     public function getConfig()
 | |
|     {
 | |
|         return $this->config;
 | |
|     }
 | |
| 
 | |
|     public function setName($name)
 | |
|     {
 | |
|         $this->name = $name;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function setHelpMessage($message)
 | |
|     {
 | |
|         $this->helpMessage = $message;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function addUsageExample($snippet, $description = '')
 | |
|     {
 | |
|         array_push($this->usageExamples, [$snippet, $description]);
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function setSyntaxMessage($message)
 | |
|     {
 | |
|         $this->syntaxMessage = $message;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function getInfoMessage()
 | |
|     {
 | |
|         $indent = str_repeat(" ", 4);
 | |
| 
 | |
|         $output = "";
 | |
|         if (!empty($this->name)) {
 | |
|             $output .= "\n";
 | |
|             $output .= "<cyan><bold>Command: </bold></cyan>";
 | |
|             $output .= $this->name;
 | |
|         }
 | |
| 
 | |
|         if (!empty($this->helpMessage)) {
 | |
|             $output .= "\n";
 | |
|             $output .= "<light_blue>{$this->helpMessage}</light_blue>\n";
 | |
|         }
 | |
| 
 | |
|         if (!empty($this->syntaxMessage)) {
 | |
|             $output .= "\n";
 | |
|             $output .= "<light_gray><bold>Syntax:</bold></light_gray>\n";
 | |
|             $output .= "$indent<light_green>{$this->syntaxMessage}</light_green>";
 | |
|             $output .= "\n";
 | |
|         }
 | |
| 
 | |
|         if (!empty($this->usageExamples)) {
 | |
|             $output .= "\n";
 | |
|             $output .= "<light_gray><bold>Usage examples:</bold></light_gray>\n";
 | |
|             foreach ($this->usageExamples as $example) {
 | |
|                 $snippet = $example[0];
 | |
|                 $description = $example[1];
 | |
|                 $output .= "$indent* ";
 | |
|                 if (!empty($description)) {
 | |
|                     $description = rtrim($description, ': ') . ":";
 | |
|                     $output .= $description;
 | |
|                     $output .= "\n$indent$indent";
 | |
|                 }
 | |
| 
 | |
|                 $output .= "<green>$snippet</green>";
 | |
|                 $output .= "\n";
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return $output;
 | |
|     }
 | |
| }
 |