X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=run.php;h=27918526de258bad5c9afc0cec412d42043eb60e;hb=b45e6d51148bf9100d302713d3f8e6885fd072a3;hp=bbf2ce691ba71e781317be0064cc569691df4f21;hpb=de71c4c4768f8f464ff61cfda3f8e31d20d2b0b0;p=wfpl.git diff --git a/run.php b/run.php index bbf2ce6..2791852 100644 --- a/run.php +++ b/run.php @@ -1,8 +1,8 @@ -load("template.html"); - $GLOBALS['wfpl_main_template']->set('basename', $basename); - - # This helps put in a stylesheet link if you have pages with custom css - if(file_exists("$basename.css")) { - $GLOBALS['wfpl_main_template']->set('css_link', "$basename.css"); - $GLOBALS['wfpl_main_template']->sub('css_links'); - } + $GLOBALS['wfpl_main_template']->set('wfpl_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 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 + # 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)) { @@ -119,7 +113,7 @@ function run_php($dest = false) { run_php('error_404'); return; } else { - echo '404

404 File Not Found

'; + echo '404

404 File Not Found

'; exit(); } } @@ -141,7 +135,7 @@ function run_php($dest = false) { run_php($other); return; } - } else { + } elseif($html_exists) { $sub_names = tem_top_sub_names(); foreach($sub_names as $sub_name) { tem_sub($sub_name); @@ -149,19 +143,29 @@ function run_php($dest = false) { } # Check for $GLOBALS['wfpl_template'] because it might have been set (or unset) by the php script. - if($GLOBALS['wfpl_template']) { - if(isset($GLOBALS['wfpl_main_template'])) { - $sections = tem_top_subs(); - if($sections) foreach($sections as $name => $val) { - $GLOBALS['wfpl_main_template']->append($name, $val); + 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 you have a site-wide template (template.html) then messages will + # be displayed there. If you instead want messages displayed on your + # page, call display_messages() from your page_main(). + # + # Either way, you'll need to require_once('code/wfpl/messages.php') + # or require_once('code/wfpl/session_messages.php'). code/config.php + # is a nice place to do this. if(function_exists('display_messages')) { display_messages(); } + tem_output(); } }