* @package PHPCI * @subpackage Plugins */ class Shell implements \PHPCI\Plugin { /** * @var \PHPCI\Builder */ protected $phpci; /** * @var \PHPCI\Model\Build */ protected $build; protected $args; /** * @var string[] $commands The commands to be executed */ protected $commands = array(); /** * Standard Constructor * * $options['directory'] Output Directory. Default: %BUILDPATH% * $options['filename'] Phar Filename. Default: build.phar * $options['regexp'] Regular Expression Filename Capture. Default: /\.php$/ * $options['stub'] Stub Content. No Default Value * * @param Builder $phpci * @param Build $build * @param array $options */ public function __construct(Builder $phpci, Build $build, array $options = array()) { $this->phpci = $phpci; $this->build = $build; if (isset($options['command'])) { // Keeping this for backwards compatibility, new projects should use interpolation vars. $options['command'] = str_replace("%buildpath%", $this->phpci->buildPath, $options['command']); $this->commands = array($options['command']); return; } /* * Support the new syntax: * * shell: * - "cd /www" * - "rm -f file.txt" */ if (is_array($options)) { $this->commands = $options; } } /** * Runs the shell command. */ public function execute() { if (!defined('ENABLE_SHELL_PLUGIN') || !ENABLE_SHELL_PLUGIN) { throw new \Exception('The shell plugin is not enabled.'); } $success = true; foreach ($this->commands as $command) { $command = $this->phpci->interpolate($command); if (!$this->phpci->executeCommand($command)) { $success = false; } } return $success; } }