X-Git-Url: https://git.cweiske.de/phorkie.git/blobdiff_plain/71c2c412f7098050479f496292bc694095d9ec97..894b39fb81760fb6fbff105159da993b512f8ce3:/src/phorkie/Repositories.php diff --git a/src/phorkie/Repositories.php b/src/phorkie/Repositories.php index a75f2c2..c605996 100644 --- a/src/phorkie/Repositories.php +++ b/src/phorkie/Repositories.php @@ -16,23 +16,25 @@ class Repositories { chdir($this->gitDir); $dirs = glob('*.git', GLOB_ONLYDIR); - array_walk( - $dirs, - function ($dir) { - return substr($dir, 0, -4); - } - ); + foreach ($dirs as $key => $dir) { + $dirs[$key] = substr($dir, 0, -4); + } sort($dirs, SORT_NUMERIC); - $n = end($dirs) + 1; + + if ($GLOBALS['phorkie']['cfg']['randomIds']) { + $n = end($dirs) + mt_rand(65536, 16777216); + } else { + $n = end($dirs) + 1; + } chdir($this->workDir); $dir = $this->workDir . '/' . $n . '/'; - mkdir($dir, 0777);//FIXME + mkdir($dir, fileperms($this->workDir) & 0777); $r = new Repository(); $r->id = $n; $r->workDir = $dir; $r->gitDir = $this->gitDir . '/' . $n . '.git/'; - mkdir($r->gitDir, 0777);//FIXME + mkdir($r->gitDir, fileperms($this->gitDir) & 0777); return $r; } @@ -40,7 +42,7 @@ class Repositories /** * Get a list of repository objects * - * @param integer $page Page number, beginning with 0 + * @param integer $page Page number, beginning with 0, or "last" * @param integer $perPage Number of repositories per page * * @return array Array of Repositories first, number of repositories second @@ -50,15 +52,34 @@ class Repositories chdir($this->gitDir); $dirs = glob('*.git', GLOB_ONLYDIR); sort($dirs, SORT_NUMERIC); + if ($page === 'last') { + //always show the last 10 + $page = intval(count($dirs) / $perPage); + $start = count($dirs) - $perPage; + if ($start < 0) { + $start = 0; + } + $some = array_slice($dirs, $start, $perPage); + } else { + $some = array_slice($dirs, $page * $perPage, $perPage); + } - $some = array_slice($dirs, $page * $perPage, $perPage); $repos = array(); foreach ($some as $oneDir) { $r = new Repository(); - $r->loadById(substr($oneDir, 0, -4)); + try { + $r->loadById(substr($oneDir, 0, -4)); + } catch (\VersionControl_Git_Exception $e) { + if (strpos($e->getMessage(), 'does not have any commits') !== false) { + //the git repo is broken as the initial commit + // has not been finished + continue; + } + throw $e; + } $repos[] = $r; } - return array($repos, count($dirs)); + return array($repos, count($dirs), $page); } }