X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=run.php;h=a310e3f7728c2daa3a4c3f0b6765a96c0bbb2605;hb=40d0d4fdb5270bebf7754da661dcd2a0c5d03a68;hp=c67c27e1a39d2bc874c08bad0a706f869863ae6a;hpb=db864ee66dd1170c74c1adae6be91ce3109b760e;p=wfpl.git diff --git a/run.php b/run.php index c67c27e..a310e3f 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 + # 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); + $cms_content = cms_display($basename, $GLOBALS['wfpl_main_template']); if(is_string($cms_content)) { run_php($cms_content); return; @@ -100,6 +106,28 @@ function run_php($dest = false) { $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) { # files can return a basename or URL of a page to be run/displayed $other = file_run($php_file); @@ -108,41 +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

'; - exit(); + $sub_names = tem_top_sub_names(); + foreach($sub_names as $sub_name) { + tem_sub($sub_name); } } - $data =& $GLOBALS['wfpl_tem_data']; - $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('code/wfpl/messages.php') or + # require_once('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($template, $data); } run_php();