| class IDF_Views_Source␊ |
| {␊ |
| /**␊ |
| * Extension supported by the syntax highlighter.␊ |
| */␊ |
| public static $supportedExtenstions = array(␊ |
| 'ascx', 'ashx', 'asmx', 'aspx', 'browser', 'bsh', 'c', 'cl', 'cc',␊ |
| 'config', 'cpp', 'cs', 'csh', 'csproj', 'css', 'cv', 'cyc', 'el', 'fs',␊ |
| 'h', 'hh', 'hpp', 'hs', 'html', 'html', 'java', 'js', 'lisp', 'master',␊ |
| 'pas', 'perl', 'php', 'pl', 'pm', 'py', 'rb', 'scm', 'sh', 'sitemap', ␊ |
| 'skin', 'sln', 'svc', 'vala', 'vb', 'vbproj', 'vbs', 'wsdl', 'xhtml',␊ |
| 'xml', 'xsd', 'xsl', 'xslt');␊ |
| ␊ |
| /**␊ |
| * Display help on how to checkout etc.␊ |
| */␊ |
| public $help_precond = array('IDF_Precondition::accessSource');␊ |
|
| if ($request_file_info->type != 'tree') {␊ |
| $info = self::getRequestedFileMimeType($request_file_info,␊ |
| $commit, $scm);␊ |
| if (!self::isText($info)) {␊ |
| if (!IDF_FileUtil::isText($info)) {␊ |
| $rep = new Pluf_HTTP_Response($scm->getFile($request_file_info),␊ |
| $info[0]);␊ |
| $rep->headers['Content-Disposition'] = 'attachment; filename="'.$info[1].'"';␊ |
|
| $previous = substr($request_file, 0, -strlen($l.' '));␊ |
| $scmConf = $request->conf->getVal('scm', 'git');␊ |
| $props = $scm->getProperties($commit, $request_file);␊ |
| $content = self::highLight($extra['mime'], $scm->getFile($request_file_info));␊ |
| $content = IDF_FileUtil::highLight($extra['mime'], $scm->getFile($request_file_info));␊ |
| return Pluf_Shortcuts_RenderToResponse('idf/source/'.$scmConf.'/file.html',␊ |
| array(␊ |
| 'page_title' => $page_title,␊ |
|
| */␊ |
| public static function getRequestedFileMimeType($file_info, $commit, $scm)␊ |
| {␊ |
| $mime = self::getMimeType($file_info->file);␊ |
| $mime = IDF_FileUtil::getMimeType($file_info->file);␊ |
| if ('application/octet-stream' != $mime[0]) {␊ |
| return $mime;␊ |
| }␊ |
| return self::getMimeTypeFromContent($file_info->file,␊ |
| $scm->getFile($file_info));␊ |
| }␊ |
| ␊ |
| /**␊ |
| * Find the mime type of a file using the fileinfo class.␊ |
| *␊ |
| * @param string Filename/Filepath␊ |
| * @param string File content␊ |
| * @return array Mime type found or 'application/octet-stream', basename, extension␊ |
| */␊ |
| public static function getMimeTypeFromContent($file, $filedata)␊ |
| {␊ |
| $info = pathinfo($file);␊ |
| $res = array('application/octet-stream',␊ |
| $info['basename'],␊ |
| isset($info['extension']) ? $info['extension'] : 'bin');␊ |
| if (function_exists('finfo_open')) {␊ |
| $finfo = finfo_open(FILEINFO_MIME);␊ |
| $mime = finfo_buffer($finfo, $filedata);␊ |
| finfo_close($finfo);␊ |
| if ($mime) {␊ |
| $res[0] = $mime;␊ |
| }␊ |
| if (!isset($info['extension']) && $mime) {␊ |
| $res[2] = (0 === strpos($mime, 'text/')) ? 'txt' : 'bin';␊ |
| } elseif (!isset($info['extension'])) {␊ |
| $res[2] = 'bin';␊ |
| }␊ |
| }␊ |
| return $res;␊ |
| }␊ |
| ␊ |
| /**␊ |
| * Find the mime type of a file.␊ |
| *␊ |
| * Use /etc/mime.types to find the type.␊ |
| *␊ |
| * @param string Filename/Filepath␊ |
| * @param array Mime type found or 'application/octet-stream', basename, extension␊ |
| */␊ |
| public static function getMimeType($file)␊ |
| {␊ |
| $src= Pluf::f('idf_mimetypes_db', '/etc/mime.types');␊ |
| $mimes = preg_split("/\015\012|\015|\012/", file_get_contents($src));␊ |
| $info = pathinfo($file);␊ |
| if (isset($info['extension'])) {␊ |
| foreach ($mimes as $mime) {␊ |
| if ('#' != substr($mime, 0, 1)) {␊ |
| $elts = preg_split('/ |\t/', $mime, -1, PREG_SPLIT_NO_EMPTY);␊ |
| if (in_array($info['extension'], $elts)) {␊ |
| return array($elts[0], $info['basename'], $info['extension']);␊ |
| }␊ |
| }␊ |
| }␊ |
| } else {␊ |
| // we consider that if no extension and base name is all␊ |
| // uppercase, then we have a text file.␊ |
| if ($info['basename'] == strtoupper($info['basename'])) {␊ |
| return array('text/plain', $info['basename'], 'txt');␊ |
| }␊ |
| $info['extension'] = 'bin';␊ |
| }␊ |
| return array('application/octet-stream', $info['basename'], $info['extension']);␊ |
| }␊ |
| ␊ |
| /**␊ |
| * Find if a given mime type is a text file.␊ |
| * This uses the output of the self::getMimeType function.␊ |
| *␊ |
| * @param array (Mime type, file name, extension)␊ |
| * @return bool Is text␊ |
| */␊ |
| public static function isText($fileinfo)␊ |
| {␊ |
| if (0 === strpos($fileinfo[0], 'text/')) {␊ |
| return true;␊ |
| }␊ |
| $ext = 'mdtext php-dist h gitignore diff patch';␊ |
| $extra_ext = trim(Pluf::f('idf_extra_text_ext', ''));␊ |
| if (!empty($extra_ext))␊ |
| $ext .= ' ' . $extra_ext;␊ |
| $ext = array_merge(self::$supportedExtenstions, explode(' ' , $ext));␊ |
| return (in_array($fileinfo[2], $ext));␊ |
| }␊ |
| ␊ |
| public static function highLight($fileinfo, $content)␊ |
| {␊ |
| $pretty = '';␊ |
| if (self::isSupportedExtension($fileinfo[2])) {␊ |
| $pretty = ' prettyprint';␊ |
| }␊ |
| $table = array();␊ |
| $i = 1;␊ |
| foreach (preg_split("/\015\012|\015|\012/", $content) as $line) {␊ |
| $table[] = '<tr class="c-line"><td class="code-lc" id="L'.$i.'"><a href="#L'.$i.'">'.$i.'</a></td>'␊ |
| .'<td class="code mono'.$pretty.'">'.IDF_Diff::padLine(Pluf_esc($line)).'</td></tr>';␊ |
| $i++;␊ |
| }␊ |
| return Pluf_Template::markSafe(implode("\n", $table));␊ |
| }␊ |
| ␊ |
| /**␊ |
| * Test if an extension is supported by the syntax highlighter.␊ |
| *␊ |
| * @param string The extension to test␊ |
| * @return bool␊ |
| */␊ |
| public static function isSupportedExtension($extension)␊ |
| {␊ |
| return in_array($extension, self::$supportedExtenstions);␊ |
| return IDF_FileUtil::getMimeTypeFromContent($file_info->file,␊ |
| $scm->getFile($file_info));␊ |
| }␊ |
| ␊ |
| /**␊ |