JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
* New template system.
[wfpl.git] / run.php
diff --git a/run.php b/run.php
index f9c514e..26a8b36 100644 (file)
--- a/run.php
+++ b/run.php
@@ -1,23 +1,9 @@
 <?php
 
-#  Copyright (C) 2006 Jason Woofenden
+#  2006 Public Domain
 #
-#  This file is part of wfpl.
-#
-#  wfpl is free software; you can redistribute it and/or modify it under the
-#  terms of the GNU Lesser General Public License as published by the Free
-#  Software Foundation; either version 2.1 of the License, or (at your option)
-#  any later version.
-#
-#  wfpl is distributed in the hope that it will be useful, but WITHOUT ANY
-#  WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
-#  FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License for
-#  more details.
-#
-#  You should have received a copy of the GNU Lesser General Public License
-#  along with wfpl; if not, write to the Free Software Foundation, Inc., 51
-#  Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
-
+#  This file was placed into the public domain on November 16th, 2008 by it's
+#  sole author Jason Woofenden
 
 # This file facilitates making a site with mixed PHP and html files. All URLs
 # have the .html extension. One benefit of this is that you can change static
@@ -68,7 +54,7 @@ if(file_exists('code/config.php')) {
 # pass http://foo.com/bar.html to redirect to a full directory
 function run_php($dest = false) {
        if($dest) {
-               # if it's got a : it must be a full URL, redirect
+               # if it has a : it must be a full URL, redirect
                if(strpos($dest, ':')) {
                        redirect($dest);
                        exit();
@@ -100,19 +86,27 @@ function run_php($dest = false) {
 
        # cms_get can return one of:
        # 1) false to indicate that there's no cms content for this basename
-       # 2) a string to indicate a soft/full redirect just as foo_main()
-       # 3) a hash of key/value pairs to be tem_set(key,value) on the template
+       # 2) a string to request a soft/full redirect just like foo_main()
+       # 3) a hash of key/value pairs to be added to the template
        if(function_exists('cms_get')) {
                $cms_content = cms_get($basename);
                if(is_string($cms_content)) {
                        run_php($cms_content);
                        return;
                }
-       } else {
-               $cms_content = false;
        }
 
-       if(!$php_exists && !$html_exists && !$cms_content) {
+       if($php_exists) {
+               # files can return a basename or URL of a page to be run/displayed
+               $other = file_run($php_file);
+               if($other) {
+                       run_php($other);
+                       return;
+               }
+       } elseif($html_exists) {
+               readfile($html_file);
+               exit();
+       } elseif(!$cms_content) {
                header('HTTP/1.0 404 File Not Found');
                if(file_exists('404.php') || file_exists('404.html')) {
                        run_php('404');
@@ -122,57 +116,28 @@ function run_php($dest = false) {
                }
        }
 
-       # 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();
+       $data = &$GLOBALS['wfpl_template'];
+       $data['basename'] = $basename;
+       if(function_exists('display_messages')) {
+               display_messages();
        }
-
-       if($html_exists) {
-               tem_load_new($html_file);
+       if($cms_content) foreach($cms_content as $name => $value) {
+               $data[$name] .= $value;
        }
-
-       if($php_exists) {
-               # files can return a basename or URL of a page to be run/displayed
-               $other = file_run($php_file);
-               if($other) {
-                       run_php($other);
-                       return;
-               }
-       } else {
-               $sub_names = tem_top_sub_names();
-               foreach($sub_names as $sub_name) {
-                       tem_sub($sub_name);
-               }
+       if(file_exists("$basename.css")) {
+               $data['css_link'] = "$basename.css";
        }
 
-       # 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");
-                       $tem->set('basename', $basename);
-                       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();
+       if(file_exists("template.html")) {
+               $template = parse_template_file("template.html");
+               if($html_exists) {
+                       $subs = parse_template_file($html_file);
+                       $template = merge_templates($template, $subs);
                }
-               tem_output();
+       } elseif($html_exists) {
+               $template = parse_template_file("$html_file");
        }
+       if($template) print fill_template($data, $template);
 }
 
 run_php();