X-Git-Url: https://git.cyclocoop.org/%28%28?a=blobdiff_plain;f=includes%2FGitInfo.php;h=407b3cb43cfcaf38ee9aff938ce794c5c9d5e728;hb=a1f1ccee356e329e79be1b380214c84c0f389063;hp=6f7f80200b03f82ad76dced9fb602f07a041bfc9;hpb=c151d6e6871493ba4df628ae6bc5c33a7262a243;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/GitInfo.php b/includes/GitInfo.php index 6f7f80200b..407b3cb43c 100644 --- a/includes/GitInfo.php +++ b/includes/GitInfo.php @@ -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 @@ -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 ) ); }