JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
added: tem->append(). run.php supports cms. Spaces preserved in pulldown displays
[wfpl.git] / run.php
diff --git a/run.php b/run.php
index 03d849a..2407202 100644 (file)
--- a/run.php
+++ b/run.php
 
 require_once('code/wfpl/file_run.php');
 require_once('code/wfpl/http.php');
+require_once('code/wfpl/template.php');
+
+if(file_exists('code/config.php')) {
+       file_run('code/config.php');
+}
 
 function run_php($basename = false) {
-       if($basename) {
-               $html_file = "$basename.html";
-               $php_file = "$basename.php";
-       } else {
-               $html_file = $_SERVER['REDIRECT_URL'];
-               $html_file = ereg_replace('.*/', '', $html_file);
-               if($html_file == '') {
-                       $html_file = 'index.html';
+       if(!$basename) {
+               $basename = $_SERVER['REDIRECT_URL'];
+               $basename = ereg_replace('.*/', '', $basename);
+               $basename = ereg_replace('\.html$', '', $basename);
+               if($basename == '') {
+                       $basename = 'index';
                }
-               $php_file = ereg_replace('\.html$', '.php', $html_file);
        }
-       if($php_file != $html_file && file_exists($php_file)) {
-               require_once('code/wfpl/template.php');
-               if(file_exists($html_file)) {
-                       $GLOBALS['wfpl_template'] = new tem();
-                       tem_load($html_file);
+
+       $html_file = "$basename.html";
+       $php_file = "$basename.php";
+
+       $html_exists = file_exists($html_file);
+       $php_exists = file_exists($php_file);
+
+       if(function_exists('cms_get')) {
+               $cms_content = cms_get($basename);
+       } else {
+               $cms_content = false;
+       }
+
+       if(!$php_exists && !$html_exists && !$cms_content) {
+               header('HTTP/1.0 404 File Not Found');
+               if(file_exists('404.php') || file_exists('404.html')) {
+                       run_php('404');
+               } else {
+                       echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html><head><title>404</title></head><body><h1>404 File Not Found</h1></body></html>';
                }
+       }
+
+       # If there's no template.html we don't want to parse $html_file.
+       if($html_exists && !$php_exists && !file_exists('template.html')) {
+               readfile($html_file);
+               exit();
+       }
+
+       if($html_exists) {
+               tem_load_new($html_file);
+       }
+
+       if($php_exists) {
+               # files can return a basename or URL of a page to be run/displayed
                $other = file_run($php_file);
                if($other) {
                        if(strpos($other, ':')) {
                                redirect($other);
                                exit();
                        }
+                       if(substr($other, 0, 2) == './') {
+                               redirect(ereg_replace('/[^/]*$', substr($other, 1), this_url()));
+                               exit();
+                       }
                        run_php($other);
                        return;
                }
-               if(file_exists($html_file)) tem_output();
        } else {
-               if(file_exists($html_file)) {
-                       readfile($html_file);
-               } else {
-                       header('HTTP/1.0 404 File Not Found');
-                       if(file_exists('404.php') || file_exists('404.html')) {
-                               run_php('404');
-                       } else {
-                               echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html><head><title>404</title></head><body><h1>404 File Not Found</h1></body></html>';
+               $sub_names = tem_top_sub_names();
+               foreach($sub_names as $sub_name) {
+                       tem_sub($sub_name);
+               }
+       }
+
+       # Check for $GLOBALS['wfpl_template'] because it might have been set (or unset) by the php script.
+       if($GLOBALS['wfpl_template']) {
+               if(file_exists('template.html')) {
+                       $tem = new tem();
+                       $tem->load("template.html");
+                       if($cms_content) foreach($cms_content as $name => $val) {
+                               $tem->append($name, $val);
+                       }
+                       $sections = tem_top_subs();
+                       if($sections) foreach($sections as $name => $val) {
+                               $tem->append($name, $val);
+                       }
+
+                       if(file_exists("$basename.css")) {
+                               $tem->set('css_link', "$basename.css");
+                               $tem->sub('css_links');
                        }
+
+                       $GLOBALS['wfpl_template'] = $tem;
+               }
+
+               if(function_exists('display_messages')) {
+                       display_messages();
                }
+               tem_output();
        }
 }