From db15fff68499baca5705dfdd86e479ce07b0f8e7 Mon Sep 17 00:00:00 2001 From: Pedro Borges Date: Fri, 8 Jul 2016 17:49:00 -0300 Subject: [PATCH] Remove dependency on Git library as a submodule --- .gitmodules | 3 - autogit.php | 4 +- composer.json | 5 + composer.lock | 64 +++ package.json | 2 +- vendor/autoload.php | 7 + vendor/composer/ClassLoader.php | 413 ++++++++++++++++++ vendor/composer/LICENSE | 21 + vendor/composer/autoload_classmap.php | 12 + vendor/composer/autoload_namespaces.php | 9 + vendor/composer/autoload_psr4.php | 9 + vendor/composer/autoload_real.php | 52 +++ vendor/composer/autoload_static.php | 22 + vendor/composer/installed.json | 49 +++ vendor/git | 1 - vendor/sebastian/git/.gitignore | 5 + vendor/sebastian/git/LICENSE | 33 ++ vendor/sebastian/git/README.md | 14 + vendor/sebastian/git/build.xml | 30 ++ vendor/sebastian/git/composer.json | 26 ++ .../sebastian/git/src/Exception/Exception.php | 17 + .../git/src/Exception/RuntimeException.php | 17 + vendor/sebastian/git/src/Git.php | 141 ++++++ 23 files changed, 948 insertions(+), 8 deletions(-) create mode 100644 composer.json create mode 100644 composer.lock create mode 100644 vendor/autoload.php create mode 100644 vendor/composer/ClassLoader.php create mode 100644 vendor/composer/LICENSE create mode 100644 vendor/composer/autoload_classmap.php create mode 100644 vendor/composer/autoload_namespaces.php create mode 100644 vendor/composer/autoload_psr4.php create mode 100644 vendor/composer/autoload_real.php create mode 100644 vendor/composer/autoload_static.php create mode 100644 vendor/composer/installed.json delete mode 160000 vendor/git create mode 100644 vendor/sebastian/git/.gitignore create mode 100644 vendor/sebastian/git/LICENSE create mode 100644 vendor/sebastian/git/README.md create mode 100644 vendor/sebastian/git/build.xml create mode 100644 vendor/sebastian/git/composer.json create mode 100644 vendor/sebastian/git/src/Exception/Exception.php create mode 100644 vendor/sebastian/git/src/Exception/RuntimeException.php create mode 100644 vendor/sebastian/git/src/Git.php diff --git a/.gitmodules b/.gitmodules index 2ba2d3a..e69de29 100644 --- a/.gitmodules +++ b/.gitmodules @@ -1,3 +0,0 @@ -[submodule "vendor/git"] - path = vendor/git - url = git@github.com:sebastianbergmann/git.git diff --git a/autogit.php b/autogit.php index 651e939..3d55e93 100644 --- a/autogit.php +++ b/autogit.php @@ -12,9 +12,7 @@ if (class_exists('Panel') or r::has('secret')) { // Load classes - require_once(__DIR__ . DS . 'vendor' . DS . 'git' . DS . 'src' . DS . 'Git.php'); - require_once(__DIR__ . DS . 'vendor' . DS . 'git' . DS . 'src' . DS . 'Exception' . DS . 'Exception.php'); - require_once(__DIR__ . DS . 'vendor' . DS . 'git' . DS . 'src' . DS . 'Exception' . DS . 'RuntimeException.php'); + require_once(__DIR__ . DS . 'vendor' . DS . 'autoload.php'); require_once(__DIR__ . DS . 'lib' . DS . 'autogit.php'); // Load hooks diff --git a/composer.json b/composer.json new file mode 100644 index 0000000..49eee5c --- /dev/null +++ b/composer.json @@ -0,0 +1,5 @@ +{ + "require": { + "sebastian/git": "^2.1" + } +} diff --git a/composer.lock b/composer.lock new file mode 100644 index 0000000..f45dc7f --- /dev/null +++ b/composer.lock @@ -0,0 +1,64 @@ +{ + "_readme": [ + "This file locks the dependencies of your project to a known state", + "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", + "This file is @generated automatically" + ], + "hash": "debcaa1e5c513fe51385d34b7e25a487", + "content-hash": "cf843328d4a8d37f7a0d0b0287c2eef1", + "packages": [ + { + "name": "sebastian/git", + "version": "2.1.3", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/git.git", + "reference": "5100bc50cd9e70f424c643618e142214225024f3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/git/zipball/5100bc50cd9e70f424c643618e142214225024f3", + "reference": "5100bc50cd9e70f424c643618e142214225024f3", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.1-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Simple wrapper for Git", + "homepage": "http://www.github.com/sebastianbergmann/git", + "keywords": [ + "git" + ], + "time": "2016-06-15 09:30:19" + } + ], + "packages-dev": [], + "aliases": [], + "minimum-stability": "stable", + "stability-flags": [], + "prefer-stable": false, + "prefer-lowest": false, + "platform": [], + "platform-dev": [] +} diff --git a/package.json b/package.json index fc9ae2c..fd6418c 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "autogit", "author": "Pedro Borges ", - "version": "0.2.0", + "version": "0.3.0", "description": "Kirby Auto Git Plugin", "type": "kirby-plugin", "license": "MIT" diff --git a/vendor/autoload.php b/vendor/autoload.php new file mode 100644 index 0000000..c2ff96e --- /dev/null +++ b/vendor/autoload.php @@ -0,0 +1,7 @@ + + * Jordi Boggiano + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Composer\Autoload; + +/** + * ClassLoader implements a PSR-0, PSR-4 and classmap class loader. + * + * $loader = new \Composer\Autoload\ClassLoader(); + * + * // register classes with namespaces + * $loader->add('Symfony\Component', __DIR__.'/component'); + * $loader->add('Symfony', __DIR__.'/framework'); + * + * // activate the autoloader + * $loader->register(); + * + * // to enable searching the include path (eg. for PEAR packages) + * $loader->setUseIncludePath(true); + * + * In this example, if you try to use a class in the Symfony\Component + * namespace or one of its children (Symfony\Component\Console for instance), + * the autoloader will first look for the class under the component/ + * directory, and it will then fallback to the framework/ directory if not + * found before giving up. + * + * This class is loosely based on the Symfony UniversalClassLoader. + * + * @author Fabien Potencier + * @author Jordi Boggiano + * @see http://www.php-fig.org/psr/psr-0/ + * @see http://www.php-fig.org/psr/psr-4/ + */ +class ClassLoader +{ + // PSR-4 + private $prefixLengthsPsr4 = array(); + private $prefixDirsPsr4 = array(); + private $fallbackDirsPsr4 = array(); + + // PSR-0 + private $prefixesPsr0 = array(); + private $fallbackDirsPsr0 = array(); + + private $useIncludePath = false; + private $classMap = array(); + + private $classMapAuthoritative = false; + + public function getPrefixes() + { + if (!empty($this->prefixesPsr0)) { + return call_user_func_array('array_merge', $this->prefixesPsr0); + } + + return array(); + } + + public function getPrefixesPsr4() + { + return $this->prefixDirsPsr4; + } + + public function getFallbackDirs() + { + return $this->fallbackDirsPsr0; + } + + public function getFallbackDirsPsr4() + { + return $this->fallbackDirsPsr4; + } + + public function getClassMap() + { + return $this->classMap; + } + + /** + * @param array $classMap Class to filename map + */ + public function addClassMap(array $classMap) + { + if ($this->classMap) { + $this->classMap = array_merge($this->classMap, $classMap); + } else { + $this->classMap = $classMap; + } + } + + /** + * Registers a set of PSR-0 directories for a given prefix, either + * appending or prepending to the ones previously set for this prefix. + * + * @param string $prefix The prefix + * @param array|string $paths The PSR-0 root directories + * @param bool $prepend Whether to prepend the directories + */ + public function add($prefix, $paths, $prepend = false) + { + if (!$prefix) { + if ($prepend) { + $this->fallbackDirsPsr0 = array_merge( + (array) $paths, + $this->fallbackDirsPsr0 + ); + } else { + $this->fallbackDirsPsr0 = array_merge( + $this->fallbackDirsPsr0, + (array) $paths + ); + } + + return; + } + + $first = $prefix[0]; + if (!isset($this->prefixesPsr0[$first][$prefix])) { + $this->prefixesPsr0[$first][$prefix] = (array) $paths; + + return; + } + if ($prepend) { + $this->prefixesPsr0[$first][$prefix] = array_merge( + (array) $paths, + $this->prefixesPsr0[$first][$prefix] + ); + } else { + $this->prefixesPsr0[$first][$prefix] = array_merge( + $this->prefixesPsr0[$first][$prefix], + (array) $paths + ); + } + } + + /** + * Registers a set of PSR-4 directories for a given namespace, either + * appending or prepending to the ones previously set for this namespace. + * + * @param string $prefix The prefix/namespace, with trailing '\\' + * @param array|string $paths The PSR-4 base directories + * @param bool $prepend Whether to prepend the directories + * + * @throws \InvalidArgumentException + */ + public function addPsr4($prefix, $paths, $prepend = false) + { + if (!$prefix) { + // Register directories for the root namespace. + if ($prepend) { + $this->fallbackDirsPsr4 = array_merge( + (array) $paths, + $this->fallbackDirsPsr4 + ); + } else { + $this->fallbackDirsPsr4 = array_merge( + $this->fallbackDirsPsr4, + (array) $paths + ); + } + } elseif (!isset($this->prefixDirsPsr4[$prefix])) { + // Register directories for a new namespace. + $length = strlen($prefix); + if ('\\' !== $prefix[$length - 1]) { + throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); + } + $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; + $this->prefixDirsPsr4[$prefix] = (array) $paths; + } elseif ($prepend) { + // Prepend directories for an already registered namespace. + $this->prefixDirsPsr4[$prefix] = array_merge( + (array) $paths, + $this->prefixDirsPsr4[$prefix] + ); + } else { + // Append directories for an already registered namespace. + $this->prefixDirsPsr4[$prefix] = array_merge( + $this->prefixDirsPsr4[$prefix], + (array) $paths + ); + } + } + + /** + * Registers a set of PSR-0 directories for a given prefix, + * replacing any others previously set for this prefix. + * + * @param string $prefix The prefix + * @param array|string $paths The PSR-0 base directories + */ + public function set($prefix, $paths) + { + if (!$prefix) { + $this->fallbackDirsPsr0 = (array) $paths; + } else { + $this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths; + } + } + + /** + * Registers a set of PSR-4 directories for a given namespace, + * replacing any others previously set for this namespace. + * + * @param string $prefix The prefix/namespace, with trailing '\\' + * @param array|string $paths The PSR-4 base directories + * + * @throws \InvalidArgumentException + */ + public function setPsr4($prefix, $paths) + { + if (!$prefix) { + $this->fallbackDirsPsr4 = (array) $paths; + } else { + $length = strlen($prefix); + if ('\\' !== $prefix[$length - 1]) { + throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); + } + $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; + $this->prefixDirsPsr4[$prefix] = (array) $paths; + } + } + + /** + * Turns on searching the include path for class files. + * + * @param bool $useIncludePath + */ + public function setUseIncludePath($useIncludePath) + { + $this->useIncludePath = $useIncludePath; + } + + /** + * Can be used to check if the autoloader uses the include path to check + * for classes. + * + * @return bool + */ + public function getUseIncludePath() + { + return $this->useIncludePath; + } + + /** + * Turns off searching the prefix and fallback directories for classes + * that have not been registered with the class map. + * + * @param bool $classMapAuthoritative + */ + public function setClassMapAuthoritative($classMapAuthoritative) + { + $this->classMapAuthoritative = $classMapAuthoritative; + } + + /** + * Should class lookup fail if not found in the current class map? + * + * @return bool + */ + public function isClassMapAuthoritative() + { + return $this->classMapAuthoritative; + } + + /** + * Registers this instance as an autoloader. + * + * @param bool $prepend Whether to prepend the autoloader or not + */ + public function register($prepend = false) + { + spl_autoload_register(array($this, 'loadClass'), true, $prepend); + } + + /** + * Unregisters this instance as an autoloader. + */ + public function unregister() + { + spl_autoload_unregister(array($this, 'loadClass')); + } + + /** + * Loads the given class or interface. + * + * @param string $class The name of the class + * @return bool|null True if loaded, null otherwise + */ + public function loadClass($class) + { + if ($file = $this->findFile($class)) { + includeFile($file); + + return true; + } + } + + /** + * Finds the path to the file where the class is defined. + * + * @param string $class The name of the class + * + * @return string|false The path if found, false otherwise + */ + public function findFile($class) + { + // work around for PHP 5.3.0 - 5.3.2 https://bugs.php.net/50731 + if ('\\' == $class[0]) { + $class = substr($class, 1); + } + + // class map lookup + if (isset($this->classMap[$class])) { + return $this->classMap[$class]; + } + if ($this->classMapAuthoritative) { + return false; + } + + $file = $this->findFileWithExtension($class, '.php'); + + // Search for Hack files if we are running on HHVM + if ($file === null && defined('HHVM_VERSION')) { + $file = $this->findFileWithExtension($class, '.hh'); + } + + if ($file === null) { + // Remember that this class does not exist. + return $this->classMap[$class] = false; + } + + return $file; + } + + private function findFileWithExtension($class, $ext) + { + // PSR-4 lookup + $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext; + + $first = $class[0]; + if (isset($this->prefixLengthsPsr4[$first])) { + foreach ($this->prefixLengthsPsr4[$first] as $prefix => $length) { + if (0 === strpos($class, $prefix)) { + foreach ($this->prefixDirsPsr4[$prefix] as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $length))) { + return $file; + } + } + } + } + } + + // PSR-4 fallback dirs + foreach ($this->fallbackDirsPsr4 as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) { + return $file; + } + } + + // PSR-0 lookup + if (false !== $pos = strrpos($class, '\\')) { + // namespaced class name + $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1) + . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR); + } else { + // PEAR-like class name + $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext; + } + + if (isset($this->prefixesPsr0[$first])) { + foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) { + if (0 === strpos($class, $prefix)) { + foreach ($dirs as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) { + return $file; + } + } + } + } + } + + // PSR-0 fallback dirs + foreach ($this->fallbackDirsPsr0 as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) { + return $file; + } + } + + // PSR-0 include paths. + if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) { + return $file; + } + } +} + +/** + * Scope isolated include. + * + * Prevents access to $this/self from included files. + */ +function includeFile($file) +{ + include $file; +} diff --git a/vendor/composer/LICENSE b/vendor/composer/LICENSE new file mode 100644 index 0000000..1a28124 --- /dev/null +++ b/vendor/composer/LICENSE @@ -0,0 +1,21 @@ + +Copyright (c) 2016 Nils Adermann, Jordi Boggiano + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is furnished +to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. + diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php new file mode 100644 index 0000000..1a204c5 --- /dev/null +++ b/vendor/composer/autoload_classmap.php @@ -0,0 +1,12 @@ + $vendorDir . '/sebastian/git/src/Exception/Exception.php', + 'SebastianBergmann\\Git\\Git' => $vendorDir . '/sebastian/git/src/Git.php', + 'SebastianBergmann\\Git\\RuntimeException' => $vendorDir . '/sebastian/git/src/Exception/RuntimeException.php', +); diff --git a/vendor/composer/autoload_namespaces.php b/vendor/composer/autoload_namespaces.php new file mode 100644 index 0000000..b7fc012 --- /dev/null +++ b/vendor/composer/autoload_namespaces.php @@ -0,0 +1,9 @@ += 50600 && !defined('HHVM_VERSION'); + if ($useStaticLoader) { + require_once __DIR__ . '/autoload_static.php'; + + call_user_func(\Composer\Autoload\ComposerStaticInit416ef15d434fc90f406c0165015e55cf::getInitializer($loader)); + } else { + $map = require __DIR__ . '/autoload_namespaces.php'; + foreach ($map as $namespace => $path) { + $loader->set($namespace, $path); + } + + $map = require __DIR__ . '/autoload_psr4.php'; + foreach ($map as $namespace => $path) { + $loader->setPsr4($namespace, $path); + } + + $classMap = require __DIR__ . '/autoload_classmap.php'; + if ($classMap) { + $loader->addClassMap($classMap); + } + } + + $loader->register(true); + + return $loader; + } +} diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php new file mode 100644 index 0000000..5fc8e1e --- /dev/null +++ b/vendor/composer/autoload_static.php @@ -0,0 +1,22 @@ + __DIR__ . '/..' . '/sebastian/git/src/Exception/Exception.php', + 'SebastianBergmann\\Git\\Git' => __DIR__ . '/..' . '/sebastian/git/src/Git.php', + 'SebastianBergmann\\Git\\RuntimeException' => __DIR__ . '/..' . '/sebastian/git/src/Exception/RuntimeException.php', + ); + + public static function getInitializer(ClassLoader $loader) + { + return \Closure::bind(function () use ($loader) { + $loader->classMap = ComposerStaticInit416ef15d434fc90f406c0165015e55cf::$classMap; + + }, null, ClassLoader::class); + } +} diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json new file mode 100644 index 0000000..7f6991f --- /dev/null +++ b/vendor/composer/installed.json @@ -0,0 +1,49 @@ +[ + { + "name": "sebastian/git", + "version": "2.1.3", + "version_normalized": "2.1.3.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/git.git", + "reference": "5100bc50cd9e70f424c643618e142214225024f3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/git/zipball/5100bc50cd9e70f424c643618e142214225024f3", + "reference": "5100bc50cd9e70f424c643618e142214225024f3", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "time": "2016-06-15 09:30:19", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.1-dev" + } + }, + "installation-source": "dist", + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Simple wrapper for Git", + "homepage": "http://www.github.com/sebastianbergmann/git", + "keywords": [ + "git" + ] + } +] diff --git a/vendor/git b/vendor/git deleted file mode 160000 index 5100bc5..0000000 --- a/vendor/git +++ /dev/null @@ -1 +0,0 @@ -Subproject commit 5100bc50cd9e70f424c643618e142214225024f3 diff --git a/vendor/sebastian/git/.gitignore b/vendor/sebastian/git/.gitignore new file mode 100644 index 0000000..ca4892d --- /dev/null +++ b/vendor/sebastian/git/.gitignore @@ -0,0 +1,5 @@ +/.idea +/vendor +/composer.lock +/composer.phar +/cache.properties diff --git a/vendor/sebastian/git/LICENSE b/vendor/sebastian/git/LICENSE new file mode 100644 index 0000000..597f70a --- /dev/null +++ b/vendor/sebastian/git/LICENSE @@ -0,0 +1,33 @@ +Git + +Copyright (c) 2013-2016, Sebastian Bergmann . +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions +are met: + + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in + the documentation and/or other materials provided with the + distribution. + + * Neither the name of Sebastian Bergmann nor the names of his + contributors may be used to endorse or promote products derived + from this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +POSSIBILITY OF SUCH DAMAGE. diff --git a/vendor/sebastian/git/README.md b/vendor/sebastian/git/README.md new file mode 100644 index 0000000..4dbaf3e --- /dev/null +++ b/vendor/sebastian/git/README.md @@ -0,0 +1,14 @@ +# Git + +Simple PHP wrapper for Git. + +## Installation + +To add this package as a local, per-project dependency to your project, simply add a dependency on `sebastian/git` to your project's `composer.json` file. Here is a minimal example of a `composer.json` file that just defines a dependency on Git 1.0: + + { + "require": { + "sebastian/git": "1.0.*" + } + } + diff --git a/vendor/sebastian/git/build.xml b/vendor/sebastian/git/build.xml new file mode 100644 index 0000000..360c131 --- /dev/null +++ b/vendor/sebastian/git/build.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/vendor/sebastian/git/composer.json b/vendor/sebastian/git/composer.json new file mode 100644 index 0000000..d9d8a8c --- /dev/null +++ b/vendor/sebastian/git/composer.json @@ -0,0 +1,26 @@ +{ + "name": "sebastian/git", + "description": "Simple wrapper for Git", + "keywords": ["git"], + "homepage": "http://www.github.com/sebastianbergmann/git", + "license": "BSD-3-Clause", + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "require": { + "php": ">=5.3.3" + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "extra": { + "branch-alias": { + "dev-master": "2.1-dev" + } + } +} diff --git a/vendor/sebastian/git/src/Exception/Exception.php b/vendor/sebastian/git/src/Exception/Exception.php new file mode 100644 index 0000000..e9f5f2b --- /dev/null +++ b/vendor/sebastian/git/src/Exception/Exception.php @@ -0,0 +1,17 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace SebastianBergmann\Git; + +/** + */ +interface Exception +{ +} diff --git a/vendor/sebastian/git/src/Exception/RuntimeException.php b/vendor/sebastian/git/src/Exception/RuntimeException.php new file mode 100644 index 0000000..5cad231 --- /dev/null +++ b/vendor/sebastian/git/src/Exception/RuntimeException.php @@ -0,0 +1,17 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace SebastianBergmann\Git; + +/** + */ +class RuntimeException extends \RuntimeException implements Exception +{ +} diff --git a/vendor/sebastian/git/src/Git.php b/vendor/sebastian/git/src/Git.php new file mode 100644 index 0000000..89626a6 --- /dev/null +++ b/vendor/sebastian/git/src/Git.php @@ -0,0 +1,141 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace SebastianBergmann\Git; + +use DateTime; + +/** + */ +class Git +{ + /** + * @var string + */ + private $repositoryPath; + + /** + * @param string $repositoryPath + */ + public function __construct($repositoryPath) + { + if (!is_dir($repositoryPath)) { + throw new RuntimeException( + sprintf( + 'Directory "%s" does not exist', + $repositoryPath + ) + ); + } + + $this->repositoryPath = realpath($repositoryPath); + } + + /** + * @param string $revision + */ + public function checkout($revision) + { + $this->execute( + 'checkout --force --quiet ' . $revision . ' 2>&1' + ); + } + + /** + * @return string + */ + public function getCurrentBranch() + { + $output = $this->execute('symbolic-ref --short HEAD'); + + return $output[0]; + } + + /** + * @param string $from + * @param string $to + * @return string + */ + public function getDiff($from, $to) + { + $output = $this->execute( + 'diff --no-ext-diff ' . $from . ' ' . $to + ); + + return implode("\n", $output); + } + + /** + * @return array + */ + public function getRevisions() + { + $output = $this->execute( + 'log --no-merges --date-order --reverse --format=medium' + ); + + $numLines = count($output); + $revisions = array(); + + for ($i = 0; $i < $numLines; $i++) { + $tmp = explode(' ', $output[$i]); + + if ($tmp[0] == 'commit') { + $sha1 = $tmp[1]; + } elseif ($tmp[0] == 'Author:') { + $author = implode(' ', array_slice($tmp, 1)); + } elseif ($tmp[0] == 'Date:' && isset($author) && isset($sha1)) { + $revisions[] = array( + 'author' => $author, + 'date' => DateTime::createFromFormat( + 'D M j H:i:s Y O', + implode(' ', array_slice($tmp, 3)) + ), + 'sha1' => $sha1, + 'message' => isset($output[$i+2]) ? trim($output[$i+2]) : '' + ); + + unset($author); + unset($sha1); + } + } + + return $revisions; + } + + /** + * @return bool + */ + public function isWorkingCopyClean() + { + $output = $this->execute('status'); + + return $output[count($output)-1] == 'nothing to commit, working directory clean'; + } + + /** + * @param string $command + * @throws RuntimeException + */ + protected function execute($command) + { + $command = 'git -C ' . escapeshellarg($this->repositoryPath) . ' ' . $command; + if (DIRECTORY_SEPARATOR == '/') { + $command = 'LC_ALL=en_US.UTF-8 ' . $command; + } + exec($command, $output, $returnValue); + + if ($returnValue !== 0) { + throw new RuntimeException(implode("\r\n", $output)); + } + + return $output; + } +}