X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2FGitInfo.php;h=6f7f80200b03f82ad76dced9fb602f07a041bfc9;hb=a14bcc6ebe8afcd06de20f10f6fdce65ce648712;hp=0867cd92bcefee8205e2d30348d5afad15ce0e00;hpb=83d509123c35196df82e01824ded68ef6fbf0cee;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/GitInfo.php b/includes/GitInfo.php index 0867cd92bc..f49f9be138 100644 --- a/includes/GitInfo.php +++ b/includes/GitInfo.php @@ -41,7 +41,7 @@ class GitInfo { private static $viewers = false; /** - * @param $dir string The root directory of the repo where the .git dir can be found + * @param string $dir The root directory of the repo where the .git dir can be found */ public function __construct( $dir ) { $this->basedir = "{$dir}/.git"; @@ -70,7 +70,7 @@ class GitInfo { /** * Check if a string looks like a hex encoded SHA1 hash * - * @param $str string The string to check + * @param string $str The string to check * @return bool Whether or not the string looks like a SHA1 */ public static function isSHA1( $str ) { @@ -120,6 +120,32 @@ class GitInfo { return $sha1; } + /** + * Return the commit date of HEAD entry of the git code repository + * + * @since 1.22 + * @return int|bool Commit date (UNIX timestamp) or false + */ + public function getHeadCommitDate() { + global $wgGitBin; + + if ( !is_file( $wgGitBin ) || !is_executable( $wgGitBin ) ) { + return false; + } + + $environment = array( "GIT_DIR" => $this->basedir ); + $cmd = wfEscapeShellArg( $wgGitBin ) . " show -s --format=format:%ct HEAD"; + $retc = false; + $commitDate = wfShellExec( $cmd, $retc, $environment ); + + if ( $retc !== 0 ) { + return false; + } else { + return (int)$commitDate; + } + + } + /** * Return the name of the current branch, or HEAD if not found * @return string The branch name, HEAD, or false @@ -136,7 +162,7 @@ class GitInfo { /** * Get an URL to a web viewer link to the HEAD revision. * - * @return string|bool string if an URL is available or false otherwise. + * @return string|bool string if a URL is available or false otherwise. */ public function getHeadViewUrl() { $config = "{$this->basedir}/config"; @@ -151,7 +177,7 @@ class GitInfo { if ( isset( $configArray['remote origin'] ) ) { $remote = $configArray['remote origin']; } else { - foreach( $configArray as $sectionName => $sectionConf ) { + foreach ( $configArray as $sectionName => $sectionConf ) { if ( substr( $sectionName, 0, 6 ) == 'remote' ) { $remote = $sectionConf; } @@ -166,14 +192,15 @@ class GitInfo { if ( substr( $url, -4 ) !== '.git' ) { $url .= '.git'; } - foreach( self::getViewers() as $repo => $viewer ) { + foreach ( self::getViewers() as $repo => $viewer ) { $pattern = '#^' . $repo . '$#'; - if ( preg_match( $pattern, $url ) ) { + if ( preg_match( $pattern, $url, $matches ) ) { $viewerUrl = preg_replace( $pattern, $viewer, $url ); $headSHA1 = $this->getHeadSHA1(); $replacements = array( '%h' => substr( $headSHA1, 0, 7 ), - '%H' => $headSHA1 + '%H' => $headSHA1, + '%r' => urlencode( $matches[1] ), ); return strtr( $viewerUrl, $replacements ); } @@ -212,7 +239,7 @@ class GitInfo { protected static function getViewers() { global $wgGitRepositoryViewers; - if( self::$viewers === false ) { + if ( self::$viewers === false ) { self::$viewers = $wgGitRepositoryViewers; wfRunHooks( 'GitViewers', array( &self::$viewers ) ); }