Fixes vim mode line.
[platal.git] / classes / plpage.php
index 56b0c8a..b79fa1c 100644 (file)
@@ -45,7 +45,7 @@ abstract class PlPage extends Smarty
         $this->template_dir  = $globals->spoolroot . '/templates/';
         $this->compile_dir   = $globals->spoolroot . '/spool/templates_c/';
         array_unshift($this->plugins_dir,
-                      $globals->spoolroot . '/core/plugins/',
+                      $globals->coreroot . '/plugins/',
                       $globals->spoolroot . '/plugins/');
         $this->config_dir    = $globals->spoolroot . '/configs/';
 
@@ -60,6 +60,7 @@ abstract class PlPage extends Smarty
                              . " actuellement désactivée, en particulier aucune donnée ne sera sauvegardée");
         }
         $this->register_prefilter('at_to_globals');
+        $this->register_prefilter('get_class_constants');
     }
 
     // }}}
@@ -78,7 +79,7 @@ abstract class PlPage extends Smarty
     public static function getCoreTpl($tpl)
     {
         global $globals;
-        return $globals->spoolroot . '/core/templates/' . $tpl;
+        return $globals->coreroot . '/templates/' . $tpl;
     }
 
     // }}}
@@ -88,7 +89,6 @@ abstract class PlPage extends Smarty
      */
     public function coreTpl($tpl, $type = SKINNED)
     {
-        global $globals;
         $this->changeTpl(self::getCoreTpl($tpl), $type);
     }
 
@@ -316,12 +316,16 @@ abstract class PlPage extends Smarty
     // }}}
     // {{{ function addJsLink
 
-    public function addJsLink($filename, $static_content = true)
+    public function addJsLink($filename, $internal = true, $static_content = true)
     {
-        if ($static_content) {
-            $this->append('pl_js', pl_static_content_path("javascript/", $filename));
+        if ($internal) {
+            if ($static_content) {
+                $this->append('pl_js', pl_static_content_path("javascript/", $filename));
+            } else {
+                $this->append('pl_js', "javascript/$filename");
+            }
         } else {
-            $this->append('pl_js', "javascript/$filename");
+            $this->append('pl_js', $filename);
         }
     }
 
@@ -459,6 +463,27 @@ function at_to_globals($tpl_source, $smarty)
 }
 
 // }}}
+// {{{ function get_class_constants()
+
+/**
+ * helper
+ */
+
+function _get_class_const($class, $const)
+{
+    return var_export(constant($class . '::' . $const), true);
+}
+
+/**
+ * Compilation plugin used to import class constants through calls to #Class::CONSTANT#
+ */
+
+function get_class_constants($tpl_source, $smarty)
+{
+    return preg_replace('/#([a-zA-Z0-9_]+)::([A-Z0-9_]+)#/e', '_get_class_const(\'\\1\',\'\\2\')', $tpl_source);
+}
+
+// }}}
 // {{{  function trimwhitespace
 
 function trimwhitespace($source, $smarty)
@@ -490,7 +515,7 @@ function core_include($source, $smarty)
 {
     global $globals;
     return preg_replace('/\{include( [^}]*)? core=([^} ]+)(.*?)\}/ui',
-                        '{include\1 file="' . $globals->spoolroot . '/core/templates/\2"\3}',
+                        '{include\1 file="' . $globals->coreroot . '/templates/\2"\3}',
                         $source);
 }
 
@@ -560,5 +585,5 @@ function hide_emails($source, $smarty)
 
 // }}}
 
-// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
+// vim:set et sw=4 sts=4 sws=4 foldmethod=marker fenc=utf-8:
 ?>