1
0
Fork 0

Added isDebug to IOInterface and improved debug messages for VcsRepositories

pull/517/head
Tiago Ribeiro 2012-04-01 03:32:00 +01:00
parent 7a28a2d83a
commit 67885d8585
4 changed files with 40 additions and 21 deletions

View File

@ -55,6 +55,14 @@ class ConsoleIO implements IOInterface
return $this->input->isInteractive(); return $this->input->isInteractive();
} }
/**
* {@inheritDoc}
*/
public function isVerbose()
{
return (Boolean) $this->input->getOption('verbose');
}
/** /**
* {@inheritDoc} * {@inheritDoc}
*/ */

View File

@ -26,6 +26,13 @@ interface IOInterface
*/ */
function isInteractive(); function isInteractive();
/**
* Is this input verbose?
*
* @return Boolean
*/
function isVerbose();
/** /**
* Writes a message to the output. * Writes a message to the output.
* *

View File

@ -27,6 +27,14 @@ class NullIO implements IOInterface
return false; return false;
} }
/**
* {@inheritDoc}
*/
public function isVerbose()
{
return false;
}
/** /**
* {@inheritDoc} * {@inheritDoc}
*/ */

View File

@ -27,7 +27,7 @@ class VcsRepository extends ArrayRepository
{ {
protected $url; protected $url;
protected $packageName; protected $packageName;
protected $debug; protected $verbose;
protected $io; protected $io;
protected $versionParser; protected $versionParser;
protected $type; protected $type;
@ -46,11 +46,7 @@ class VcsRepository extends ArrayRepository
$this->url = $config['url']; $this->url = $config['url'];
$this->io = $io; $this->io = $io;
$this->type = isset($config['type']) ? $config['type'] : 'vcs'; $this->type = isset($config['type']) ? $config['type'] : 'vcs';
} $this->verbose = $io->isVerbose();
public function setDebug($debug)
{
$this->debug = $debug;
} }
public function getDriver() public function getDriver()
@ -83,7 +79,7 @@ class VcsRepository extends ArrayRepository
{ {
parent::initialize(); parent::initialize();
$debug = $this->debug; $verbose = $this->verbose;
$driver = $this->getDriver(); $driver = $this->getDriver();
if (!$driver) { if (!$driver) {
@ -99,21 +95,21 @@ class VcsRepository extends ArrayRepository
$this->packageName = !empty($data['name']) ? $data['name'] : null; $this->packageName = !empty($data['name']) ? $data['name'] : null;
} }
} catch (\Exception $e) { } catch (\Exception $e) {
if ($debug) { if ($verbose) {
$this->io->write('Skipped parsing '.$driver->getRootIdentifier().', '.$e->getMessage()); $this->io->write('Skipped parsing '.$driver->getRootIdentifier().', '.$e->getMessage());
} }
} }
foreach ($driver->getTags() as $tag => $identifier) { foreach ($driver->getTags() as $tag => $identifier) {
$msg = 'Get composer info for <info>' . $this->packageName . '</info> (<comment>' . $tag . '</comment>)'; $msg = 'Get composer info for <info>' . ($this->packageName ?: $this->url) . '</info> (<comment>' . $tag . '</comment>)';
if ($debug) { if ($verbose) {
$this->io->write($msg); $this->io->write($msg);
} else { } else {
$this->io->overwrite($msg, false); $this->io->overwrite($msg, false);
} }
if (!$parsedTag = $this->validateTag($tag)) { if (!$parsedTag = $this->validateTag($tag)) {
if ($debug) { if ($verbose) {
$this->io->write('Skipped tag '.$tag.', invalid tag name'); $this->io->write('Skipped tag '.$tag.', invalid tag name');
} }
continue; continue;
@ -121,13 +117,13 @@ class VcsRepository extends ArrayRepository
try { try {
if (!$data = $driver->getComposerInformation($identifier)) { if (!$data = $driver->getComposerInformation($identifier)) {
if ($debug) { if ($verbose) {
$this->io->write('Skipped tag '.$tag.', no composer file'); $this->io->write('Skipped tag '.$tag.', no composer file');
} }
continue; continue;
} }
} catch (\Exception $e) { } catch (\Exception $e) {
if ($debug) { if ($verbose) {
$this->io->write('Skipped tag '.$tag.', '.($e instanceof TransportException ? 'no composer file was found' : $e->getMessage())); $this->io->write('Skipped tag '.$tag.', '.($e instanceof TransportException ? 'no composer file was found' : $e->getMessage()));
} }
continue; continue;
@ -148,13 +144,13 @@ class VcsRepository extends ArrayRepository
// broken package, version doesn't match tag // broken package, version doesn't match tag
if ($data['version_normalized'] !== $parsedTag) { if ($data['version_normalized'] !== $parsedTag) {
if ($debug) { if ($verbose) {
$this->io->write('Skipped tag '.$tag.', tag ('.$parsedTag.') does not match version ('.$data['version_normalized'].') in composer.json'); $this->io->write('Skipped tag '.$tag.', tag ('.$parsedTag.') does not match version ('.$data['version_normalized'].') in composer.json');
} }
continue; continue;
} }
if ($debug) { if ($verbose) {
$this->io->write('Importing tag '.$tag.' ('.$data['version_normalized'].')'); $this->io->write('Importing tag '.$tag.' ('.$data['version_normalized'].')');
} }
@ -164,15 +160,15 @@ class VcsRepository extends ArrayRepository
$this->io->overwrite('', false); $this->io->overwrite('', false);
foreach ($driver->getBranches() as $branch => $identifier) { foreach ($driver->getBranches() as $branch => $identifier) {
$msg = 'Get composer info for <info>' . $this->packageName . '</info> (<comment>' . $branch . '</comment>)'; $msg = 'Get composer info for <info>' . ($this->packageName ?: $this->url) . '</info> (<comment>' . $branch . '</comment>)';
if ($debug) { if ($verbose) {
$this->io->write($msg); $this->io->write($msg);
} else { } else {
$this->io->overwrite($msg, false); $this->io->overwrite($msg, false);
} }
if (!$parsedBranch = $this->validateBranch($branch)) { if (!$parsedBranch = $this->validateBranch($branch)) {
if ($debug) { if ($verbose) {
$this->io->write('Skipped branch '.$branch.', invalid name'); $this->io->write('Skipped branch '.$branch.', invalid name');
} }
continue; continue;
@ -180,13 +176,13 @@ class VcsRepository extends ArrayRepository
try { try {
if (!$data = $driver->getComposerInformation($identifier)) { if (!$data = $driver->getComposerInformation($identifier)) {
if ($debug) { if ($verbose) {
$this->io->write('Skipped branch '.$branch.', no composer file'); $this->io->write('Skipped branch '.$branch.', no composer file');
} }
continue; continue;
} }
} catch (TransportException $e) { } catch (TransportException $e) {
if ($debug) { if ($verbose) {
$this->io->write('Skipped branch '.$branch.', no composer file was found'); $this->io->write('Skipped branch '.$branch.', no composer file was found');
} }
continue; continue;
@ -206,7 +202,7 @@ class VcsRepository extends ArrayRepository
$data['version'] = $data['version'] . '-dev'; $data['version'] = $data['version'] . '-dev';
} }
if ($debug) { if ($verbose) {
$this->io->write('Importing branch '.$branch.' ('.$data['version_normalized'].')'); $this->io->write('Importing branch '.$branch.' ('.$data['version_normalized'].')');
} }