repo = $repo; $this->project = $project; } /** * Returns an instance of the correct scm backend object. * * @param IDF_Project * @return Object */ public static function get($project=null) { // Get scm type from project conf ; defaults to git // We will need to cache the factory $scm = $project->getConf()->getVal('scm', 'git'); $scms = Pluf::f('allowed_scm'); return call_user_func(array($scms[$scm], 'factory'), $project); } /** * Check if the backend is available for display. * * @return bool Available */ public function isAvailable() { throw new Pluf_Exception_NotImplemented(); } /** * Returns the list of branches. * * @return array For example array('trunk', '1.0branch') */ public function getBranches() { throw new Pluf_Exception_NotImplemented(); } /** * Returns the list of tags. * * @return array For example array('v0.9', 'v1.0') */ public function getTags() { throw new Pluf_Exception_NotImplemented(); } /** * Returns the main branch. * * The main branch is the one displayed by default. For example * master, trunk or tip. * * @return string */ public function getMainBranch() { throw new Pluf_Exception_NotImplemented(); } /** * Returns the list of files in a given folder. * * The list is an array of standard class objects with attributes * for each file/directory/external element. * * This is the most important method of the SCM backend as this is * the one conveying the speed feeling of the application. All the * dirty optimization tricks are allowed there. * * @param string Revision or commit * @param string Folder ('/') * @param string Branch (null) * @return array */ public function getTree($rev, $folder='/', $branch=null) { throw new Pluf_Exception_NotImplemented(); } /** * Get commit details. * * @param string Commit or revision number * @param bool Get commit diff (false) * @return stdClass */ public function getCommit($commit, $getdiff=false) { throw new Pluf_Exception_NotImplemented(); } /** * Get latest changes. * * It default to the main branch. If possible you should code in a * way to avoid repetitive calls to getCommit. Try to be * efficient. * * @param string Branch (null) * @param int Number of changes (25) * @return array List of commits */ public function getChangeLog($branch=null, $n=10) { throw new Pluf_Exception_NotImplemented(); } /** * Given the string describing the author from the log find the * author in the database. * * If the input is an array, it will return an array of results. * * @param mixed string/array Author * @return mixed Pluf_User or null or array */ public function findAuthor($author) { throw new Pluf_Exception_NotImplemented(); } /** * Given a revision and a file path, retrieve the file content. * * The third parameter is to only request the command that is used * to get the file content. This is used when downloading a file * at a given revision as it can be passed to a * Pluf_HTTP_Response_CommandPassThru reponse. This allows to * stream a large response without buffering it in memory. * * The file definition can be a hash or a path depending on the * SCM. * * @param string File definition * @param string Revision ('') * @param bool Returns command only (false) * @return string File content */ public function getFile($def, $rev='', $cmd_only=false) { throw new Pluf_Exception_NotImplemented(); } /** * Equivalent to exec but with caching. * * @param string Command * @param &array Output * @param &int Return value * @return string Last line of the output */ public static function exec($command, &$output=array(), &$return=0) { $command = Pluf::f('idf_exec_cmd_prefix', '').$command; $key = md5($command); $cache = Pluf_Cache::factory(); if (null === ($res=$cache->get($key))) { $ll = exec($command, $output, $return); if ($return != 0 and Pluf::f('debug_scm', false)) { throw new IDF_Scm_Exception(sprintf('Error when running command: "%s", return code: %d', $command, $return)); } $cache->set($key, array($ll, $return, $output)); } else { list($ll, $return, $output) = $res; } return $ll; } /** * Equivalent to shell_exec but with caching. * * @param string Command * @return string Output of the command */ public static function shell_exec($command) { $command = Pluf::f('idf_exec_cmd_prefix', '').$command; $key = md5($command); $cache = Pluf_Cache::factory(); if (null === ($res=$cache->get($key))) { $res = shell_exec($command); $cache->set($key, $res); } return $res; } /** * Sync the changes in the repository with the timeline. * */ public static function syncTimeline($project) { $cache = Pluf_Cache::factory(); $key = 'IDF_Scm:'.$project->shortname.':lastsync'; if (null === ($res=$cache->get($key))) { $scm = IDF_Scm::get($project); foreach ($scm->getBranches() as $branche) { foreach ($scm->getChangeLog($branche, 25) as $change) { IDF_Commit::getOrAdd($change, $project); } } $cache->set($key, true, (int)(Pluf::f('cache_timeout', 300)/2)); } } }