function outputMigrationHeadline(AbstractMigration $migration)
{
    global $lastMigration;
    if ($migration !== $lastMigration) {
        outputHeadline('Migration %s (%s)', 1, array($migration->getIdentifier(), formatVersion($migration->getVersionNumber())));
        $description = $migration->getDescription();
        if ($description !== null) {
            outputLine($description);
            outputLine();
        }
        $lastMigration = $migration;
    }
}
 /**
  * Commit changes done to the package described by $packageData. The migration
  * that was did the changes is given with $versionNumber and $versionPackageKey
  * and will be recorded in the commit message.
  *
  * @param AbstractMigration $migration
  * @param string $commitMessageNotice
  * @return string
  */
 protected function commitMigration(AbstractMigration $migration, $commitMessageNotice = null)
 {
     $migrationIdentifier = $migration->getIdentifier();
     $commitMessageSubject = sprintf('TASK: Apply migration %s', $migrationIdentifier);
     if (!Git::isWorkingCopyRoot($this->currentPackageData['path'])) {
         $commitMessageSubject .= sprintf(' to package "%s"', $this->currentPackageData['packageKey']);
     }
     $commitMessage = $commitMessageSubject . chr(10) . chr(10);
     $description = $migration->getDescription();
     if ($description !== null) {
         $commitMessage .= wordwrap($description, 72);
     } else {
         $commitMessage .= wordwrap(sprintf('This commit contains the result of applying migration %s to this package.', $migrationIdentifier), 72);
     }
     if ($commitMessageNotice !== null) {
         $commitMessage .= chr(10) . chr(10) . wordwrap($commitMessageNotice, 72) . chr(10) . chr(10);
     }
     list($returnCode, $output) = Git::commitAll($this->currentPackageData['path'], $commitMessage);
     if ($returnCode === 0) {
         return '    ' . implode(PHP_EOL . '    ', $output) . PHP_EOL;
     } else {
         return '    No changes were committed.' . PHP_EOL;
     }
 }