file type and language definition happens in config.default.php now
[phorkie.git] / src / Phorkie / File.php
index 84f7eb5301b448f72a8ce322a04d1ce5926367a9..34a759a5081723d9f57a79e8ac08039a5eeee596 100644 (file)
@@ -17,32 +17,7 @@ class File
      */
     public $repo;
 
-    /**
-     * Maps file extensions to MIME Types
-     *
-     * @var array
-     */
-    public static $arMimeTypeMap = array(
-        'css'  => 'text/css',
-        'htm'  => 'text/html',
-        'html' => 'text/html',
-        'js'   => 'application/javascript',
-        'php'  => 'text/x-php',
-        'txt'  => 'text/plain',
-        'xml'  => 'text/xml',
-    );
-
-    /**
-     * Maps file extensions to geshi types
-     *
-     * @var array
-     */
-    public static $arTypeMap = array(
-        'htm'  => 'xml',
-        'html' => 'xml',
-    );
-
-    public function __construct($path, Repository $repo)
+    public function __construct($path, Repository $repo = null)
     {
         $this->path = $path;
         $this->repo = $repo;
@@ -59,18 +34,23 @@ class File
     }
 
     /**
-     * Returns the type of the file, as used by Geshi
+     * Return the full path to the file
      *
      * @return string
      */
-    public function getType()
+    public function getPath()
     {
-        $ext = substr($this->path, strrpos($this->path, '.') + 1);
-        if (isset(static::$arTypeMap[$ext])) {
-            $ext = static::$arTypeMap[$ext];
-        }
+        return $this->path;
+    }
 
-        return $ext;
+    /**
+     * Get file extension without dot
+     *
+     * @return string
+     */
+    public function getExt()
+    {
+        return substr($this->path, strrpos($this->path, '.') + 1);
     }
 
     public function getContent()
@@ -84,22 +64,13 @@ class File
          * Yes, geshi needs to be in your include path
          * We use the mediawiki geshi extension package.
          */
-        require 'MediaWiki/geshi/geshi/geshi.php';
-        $geshi = new \GeSHi($this->getContent(), $this->getType());
+        require_once 'MediaWiki/geshi/geshi/geshi.php';
+        $geshi = new \GeSHi($this->getContent(), $this->getGeshiType());
         $geshi->enable_line_numbers(GESHI_NORMAL_LINE_NUMBERS);
         $geshi->set_header_type(GESHI_HEADER_DIV);
         return $geshi->parse_code();
     }
 
-    public function getMimeType()
-    {
-        $type = $this->getType();
-        if (!isset(static::$arMimeTypeMap[$type])) {
-            return null;
-        }
-        return static::$arMimeTypeMap[$type];
-    }
-
     /**
      * Get a link to the file
      *
@@ -116,6 +87,30 @@ class File
         }
         throw new Exception('Unknown type');
     }
+
+    /**
+     * Returns the type of the file, as used by Geshi
+     *
+     * @return string
+     */
+    public function getGeshiType()
+    {
+        $ext = $this->getExt();
+        if (isset($GLOBALS['phorkie']['languages'][$ext]['geshi'])) {
+            $ext = $GLOBALS['phorkie']['languages'][$ext]['geshi'];
+        }
+
+        return $ext;
+    }
+
+    public function getMimeType()
+    {
+        $ext = $this->getExt();
+        if (!isset($GLOBALS['phorkie']['languages'][$ext])) {
+            return null;
+        }
+        return $GLOBALS['phorkie']['languages'][$ext]['mime'];
+    }
 }
 
 ?>
\ No newline at end of file