JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
fixed dwt_set() so you can call it multiple times with the same name
authorJason Woofenden <jason183@herkamire.com>
Sun, 11 Nov 2007 11:13:07 +0000 (06:13 -0500)
committerJason Woofenden <jason183@herkamire.com>
Sun, 11 Nov 2007 11:13:07 +0000 (06:13 -0500)
cleaned up db_printf()
added dwt_prepend()
made lists of states and provinces globals
added tem_show_separated

db.php
dwt.php
encode.php
template.php

diff --git a/db.php b/db.php
index 23c56b5..9390035 100644 (file)
--- a/db.php
+++ b/db.php
@@ -111,7 +111,6 @@ function db_printf($str) {
 
 # This function does the work, but takes the parameters in an array
 function _db_printf($str, $args) {
-       $args = array_reverse($args); # because array_pop() takes from the end
        $out = '';
        while($str) {
                $pos = strpos($str, '%');
@@ -129,11 +128,11 @@ function _db_printf($str, $args) {
                $str = substr($str, $pos + 2);
 
                if($chr == '"') {
-                       $out .= '"' . enc_sql(array_pop($args)) . '"';
+                       $out .= '"' . enc_sql(array_shift($args)) . '"';
                } elseif($chr == 's') {
-                       $out .= enc_sql(array_pop($args));
+                       $out .= enc_sql(array_shift($args));
                } elseif($chr == 'i') {
-                       $int = format_int(array_pop($args));
+                       $int = format_int(array_shift($args));
                        if($int == '') $int = '0';
                        $out .= $int;
                } else {
diff --git a/dwt.php b/dwt.php
index 82629ff..d347753 100644 (file)
--- a/dwt.php
+++ b/dwt.php
@@ -42,8 +42,14 @@ function dwt_load($filename) {
 }
 
 function dwt_set_raw($name, $value) {
-       $GLOBALS['_dwt_keys'][] = $name;
-       $GLOBALS['_dwt_values'][] = $value;
+       $index = dwt_find_raw($name);
+       if($index) {
+               $GLOBALS['_dwt_keys'][$index] = $name;
+               $GLOBALS['_dwt_values'][$index] = $value;
+       } else {
+               $GLOBALS['_dwt_keys'][] = $name;
+               $GLOBALS['_dwt_values'][] = $value;
+       }
 }
 
 function dwt_set($name, $value) {
@@ -78,6 +84,19 @@ function dwt_append($name, $value) {
        dwt_append_raw("<!-- TemplateBeginEditable name=\"$name\" -->", $value);
 }
 
+function dwt_prepend_raw($name, $value) {
+       $index = dwt_find_raw($name);
+       if($index !== null) {
+               $GLOBALS['_dwt_values'][$index] = $value . $GLOBALS['_dwt_values'][$index];
+       } else {
+               dwt_set_raw($name, $value);
+       }
+}
+
+function dwt_prepend($name, $value) {
+       dwt_prepend_raw("<!-- TemplateBeginEditable name=\"$name\" -->", $value);
+}
+
 function dwt_output($filename = null) {
        if($filename !== null) {
                dwt_load($filename);
index fd00b97..b73a0ec 100644 (file)
@@ -236,21 +236,22 @@ function encode_options($selected, $options, $keys_from) {
        return $out;
 }
 
+$GLOBALS['wfpl_states_assoc'] = array("AL" => "Alabama", "AK" => "Alaska", "AZ" => "Arizona", "AR" => "Arkansas", "CA" => "California", "CO" => "Colorado", "CT" => "Connecticut", "DE" => "Delaware", "FL" => "Florida", "GA" => "Georgia", "HI" => "Hawaii", "ID" => "Idaho", "IL" => "Illinois", "IN" => "Indiana", "IA" => "Iowa", "KS" => "Kansas", "KY" => "Kentucky", "LA" => "Louisiana", "ME" => "Maine", "MD" => "Maryland", "MA" => "Massachusetts", "MI" => "Michigan", "MN" => "Minnesota", "MS" => "Mississippi", "MO" => "Missouri", "MT" => "Montana", "NE" => "Nebraska", "NV" => "Nevada", "NH" => "New Hampshire", "NJ" => "New Jersey", "NM" => "New Mexico", "NY" => "New York", "NC" => "North Carolina", "ND" => "North Dakota", "OH" => "Ohio", "OK" => "Oklahoma", "OR" => "Oregon", "PA" => "Pennsylvania", "RI" => "Rhode Island", "SC" => "South Carolina", "SD" => "South Dakota", "TN" => "Tennessee", "TX" => "Texas", "UT" => "Utah", "VT" => "Vermont", "VA" => "Virginia", "WA" => "Washington", "DC" => "Washington, DC", "WV" => "West Virginia", "WI" => "Wisconsin", "WY" => "Wyoming");
 
 # display <option>s
 function enc_states($str) {
-       $states_assoc = array("AL" => "Alabama", "AK" => "Alaska", "AZ" => "Arizona", "AR" => "Arkansas", "CA" => "California", "CO" => "Colorado", "CT" => "Connecticut", "DE" => "Delaware", "FL" => "Florida", "GA" => "Georgia", "HI" => "Hawaii", "ID" => "Idaho", "IL" => "Illinois", "IN" => "Indiana", "IA" => "Iowa", "KS" => "Kansas", "KY" => "Kentucky", "LA" => "Louisiana", "ME" => "Maine", "MD" => "Maryland", "MA" => "Massachusetts", "MI" => "Michigan", "MN" => "Minnesota", "MS" => "Mississippi", "MO" => "Missouri", "MT" => "Montana", "NE" => "Nebraska", "NV" => "Nevada", "NH" => "New Hampshire", "NJ" => "New Jersey", "NM" => "New Mexico", "NY" => "New York", "NC" => "North Carolina", "ND" => "North Dakota", "OH" => "Ohio", "OK" => "Oklahoma", "OR" => "Oregon", "PA" => "Pennsylvania", "RI" => "Rhode Island", "SC" => "South Carolina", "SD" => "South Dakota", "TN" => "Tennessee", "TX" => "Texas", "UT" => "Utah", "VT" => "Vermont", "VA" => "Virginia", "WA" => "Washington", "DC" => "Washington, DC", "WV" => "West Virginia", "WI" => "Wisconsin", "WY" => "Wyoming");
        $ret = '';
 
-       return encode_options($str, $states_assoc, PULLDOWN_HASH);
+       return encode_options($str, $GLOBALS['wfpl_states_assoc'], PULLDOWN_HASH);
 }
 
+$GLOBALS['wfpl_provinces_assoc'] = array("AB" => "Alberta", "BC" => "British Columbia", "MB" => "Manitoba", "NF" => "Newfoundland", "NB" => "New Brunswick", "NS" => "Nova Scotia", "NT" => "Northwest Territories", "NU" => "Nunavut", "ON" => "Ontario", "PE" => "Prince Edward Island", "QC" => "Quebec", "SK" => "Saskatchewan", "YT" => "Yukon Territory");
+
 # display <option>s
 function enc_provinces($str) {
-       $provinces_assoc = array("AB" => "Alberta", "BC" => "British Columbia", "MB" => "Manitoba", "NF" => "Newfoundland", "NB" => "New Brunswick", "NS" => "Nova Scotia", "NT" => "Northwest Territories", "NU" => "Nunavut", "ON" => "Ontario", "PE" => "Prince Edward Island", "QC" => "Quebec", "SK" => "Saskatchewan", "YT" => "Yukon Territory");
        $ret = '';
 
-       return encode_options($str, $provinces_assoc, PULLDOWN_HASH);
+       return encode_options($str, $GLOBALS['wfpl_provinces_assoc'], PULLDOWN_HASH);
 }
 
 # returns "odd", then "even", then "odd" etc.
index 2a21975..36e1ad1 100644 (file)
@@ -91,6 +91,13 @@ class tem {
                }
        }
 
+       function show_separated($sub_template_name) {
+               if($this->get($sub_template_name)) {
+                       $this->show($sub_template_name . '_sep');
+               }
+               $this->show($sub_template_name);
+       }
+
        # this is used by tem::load() and should be otherwise useless
        function _load(&$in, &$out, &$parents, &$parent) {
                while($in) {
@@ -253,6 +260,12 @@ function tem_show($sub_template_name) {
        $GLOBALS['wfpl_template']->show($sub_template_name);
 }
 
+function tem_show_separated($sub_template_name) {
+       tem_init();
+       $GLOBALS['wfpl_template']->show_separated($sub_template_name);
+}
+
+
 function tem_load($filename) {
        tem_init();
        $GLOBALS['wfpl_template']->load($filename);