X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=run.php;h=8cf9d4d14690923ee98e115ab0aee5085e3ffa01;hb=d674720715c4dd8f210d9064db032f1c862dd3fa;hp=26a8b36fffc9a14d1937b48380eb829e57fe9b19;hpb=ba50d9a564ca3b8637212c634b5a61a38e6feb9f;p=wfpl.git diff --git a/run.php b/run.php index 26a8b36..8cf9d4d 100644 --- a/run.php +++ b/run.php @@ -1,8 +1,8 @@ -load("template.html"); + $GLOBALS['wfpl_main_template']->set('$basename', $basename); + } + # cms_get can return one of: - # 1) false to indicate that there's no cms content for this basename - # 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); + # 1) true to indicate that there is cms content (so no 404) + # 2) false to indicate that there's no cms content for this basename + # 3) a string to indicate a soft/full redirect just as foo_main() + if(function_exists('cms_display')) { + $cms_content = cms_display($basename, $GLOBALS['wfpl_main_template']); if(is_string($cms_content)) { run_php($cms_content); return; } + } else { + $cms_content = false; + } + + if(!$php_exists && !$html_exists && !$cms_content) { + header('HTTP/1.0 404 File Not Found'); + if(file_exists('error_404.php') || file_exists('error_404.html')) { + $GLOBALS['error_basename'] = $basename; + run_php('error_404'); + return; + } else { + echo '404

404 File Not Found

'; + exit(); + } + } + + # 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) { @@ -104,40 +136,37 @@ function run_php($dest = false) { 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'); - return; - } else { - echo '404

404 File Not Found

'; + $sub_names = tem_top_sub_names(); + foreach($sub_names as $sub_name) { + tem_sub($sub_name); } } - $data = &$GLOBALS['wfpl_template']; - $data['basename'] = $basename; - if(function_exists('display_messages')) { - display_messages(); - } - if($cms_content) foreach($cms_content as $name => $value) { - $data[$name] .= $value; - } - 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'] || $GLOBALS['wfpl_main_template']) { + if($GLOBALS['wfpl_main_template']) { + # if there was a template for that page, and one for the whole + # site, copy all template sections that have been show()n to the + # site-wide template + if($GLOBALS['wfpl_template']) { + $GLOBALS['wfpl_main_template']->merge($GLOBALS['wfpl_template']); + } + + $GLOBALS['wfpl_template'] = $GLOBALS['wfpl_main_template']; + } - 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); + + # You'll probably want to require_once(__DIR__.'/'.'code/wfpl/messages.php') or + # require_once(__DIR__.'/'.'code/wfpl/session_messages.php') in code/config.php + if(function_exists('display_messages')) { + if(function_exists('atexit_now')) { + atexit_now(); + } + display_messages(); } - } elseif($html_exists) { - $template = parse_template_file("$html_file"); + + tem_output(); } - if($template) print fill_template($data, $template); } run_php();