X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=run.php;h=3d0b1d4d5e2bbe66a7d9b7dc1a6d7bef69e349c9;hb=27f182546d729a9d297091799fcf1a1922da0c5e;hp=c5ae240daf78dd08ddbc6199fc1e32da81891ac0;hpb=74fac1cb550d6a337c67cabdcfae4ad26e34f422;p=wfpl.git
diff --git a/run.php b/run.php
index c5ae240..3d0b1d4 100644
--- a/run.php
+++ b/run.php
@@ -1,23 +1,9 @@
404404 File Not Found
';
- }
+ $html_exists = file_exists($html_file);
+ $php_exists = file_exists($php_file);
+
+ # 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);
+ if(is_string($cms_content)) {
+ run_php($cms_content);
+ return;
}
- exit();
- }
-
- if(file_exists($html_file)) {
- $GLOBALS['wfpl_template'] = new tem();
- tem_load($html_file);
}
- # files can return a basename or URL of a page to be run/displayed
- $other = file_run($php_file);
- if($other) {
- if(strpos($other, ':')) {
- redirect($other);
- exit();
+ 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');
+ return;
+ } else {
+ echo '404404 File Not Found
';
}
- run_php($other);
- return;
}
- if($GLOBALS['wfpl_template']) {
- if(file_exists('template.html')) {
- $tem = new tem();
- $tem->load("template.html");
- $sections = tem_top_subs();
- if($sections) foreach($sections as $name => $val) {
- $tem->set($name, $val);
- }
-
- if(file_exists("$basename.css")) {
- $tem->set('css_link', "$basename.css");
- $tem->sub('css_links');
- }
-
- $GLOBALS['wfpl_template'] = $tem;
- }
+ $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";
+ }
- 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($template, $data);
}
run_php();