X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=run.php;h=09b51b56b5d7068e93fc7261348af4977b48a504;hb=7596b1ca035ff09e584e915a6e5572ffb46d7625;hp=3eca719d96dcad15b698a0123855a2eedd6a6f87;hpb=a4e42e7c89f4c256ff2512902fb539a2279785ce;p=wfpl.git diff --git a/run.php b/run.php index 3eca719..09b51b5 100644 --- a/run.php +++ b/run.php @@ -1,24 +1,9 @@ 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'); + } + } -function run_php($basename = false) { - if($basename) { - $html_file = "$basename.html"; - $php_file = "$basename.php"; + # 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 + 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 { - $html_file = $_SERVER['REDIRECT_URL']; - $html_file = ereg_replace('.*/', '', $html_file); - if($html_file == '') { - $html_file = 'index.html'; + $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'); + return; + } else { + echo '404

404 File Not Found

'; } - $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)) tem_load($html_file); + + # 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) { 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 '404

404 File Not Found

'; + $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(isset($GLOBALS['wfpl_main_template'])) { + $sections = tem_top_subs(); + if($sections) foreach($sections as $name => $val) { + $GLOBALS['wfpl_main_template']->append($name, $val); } + + $GLOBALS['wfpl_template'] = $GLOBALS['wfpl_main_template']; + } + + if(function_exists('display_messages')) { + display_messages(); } + tem_output(); } }