You are here

class Git in Drupal 9

Same name and namespace in other branches
  1. 8 composer/Plugin/Scaffold/Git.php \Drupal\Composer\Plugin\Scaffold\Git

Provide some Git utility operations

@internal

Hierarchy

  • class \Drupal\Composer\Plugin\Scaffold\Git

Expanded class hierarchy of Git

File

composer/Plugin/Scaffold/Git.php, line 13

Namespace

Drupal\Composer\Plugin\Scaffold
View source
class Git {

  /**
   * This class provides only static methods.
   */
  private function __construct() {
  }

  /**
   * Determines whether the specified scaffold file is already ignored.
   *
   * @param string $path
   *   Path to scaffold file to check.
   * @param string $dir
   *   Base directory for git process.
   *
   * @return bool
   *   Whether the specified file is already ignored or not (TRUE if ignored).
   */
  public static function checkIgnore(IOInterface $io, $path, $dir = NULL) {
    $process = new ProcessExecutor($io);
    $output = '';
    $exitCode = $process
      ->execute('git check-ignore ' . $process
      ->escape($path), $output, $dir);
    return $exitCode == 0;
  }

  /**
   * Determines whether the specified scaffold file is tracked by git.
   *
   * @param string $path
   *   Path to scaffold file to check.
   * @param string $dir
   *   Base directory for git process.
   *
   * @return bool
   *   Whether the specified file is already tracked or not (TRUE if tracked).
   */
  public static function checkTracked(IOInterface $io, $path, $dir = NULL) {
    $process = new ProcessExecutor($io);
    $output = '';
    $exitCode = $process
      ->execute('git ls-files --error-unmatch ' . $process
      ->escape($path), $output, $dir);
    return $exitCode == 0;
  }

  /**
   * Checks to see if the project root dir is in a git repository.
   *
   * @param string $dir
   *   Base directory for git process.
   * @return bool
   *   True if this is a repository.
   */
  public static function isRepository(IOInterface $io, $dir = NULL) {
    $process = new ProcessExecutor($io);
    $output = '';
    $exitCode = $process
      ->execute('git rev-parse --show-toplevel', $output, $dir);
    return $exitCode == 0;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
Git::checkIgnore public static function Determines whether the specified scaffold file is already ignored.
Git::checkTracked public static function Determines whether the specified scaffold file is tracked by git.
Git::isRepository public static function Checks to see if the project root dir is in a git repository.
Git::__construct private function This class provides only static methods.