X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=encode.php;h=6e57c36a0c9a39b0e7263f55c1525dc865e71a84;hb=d3416270f26f08e34ff1748e1ee1fef7a15e79db;hp=38b09bdd5035ea6226f9ca16d7a680e202770dd0;hpb=7add2ea3f61e40c5f0f5539ac6e02533c9390db4;p=wfpl.git diff --git a/encode.php b/encode.php index 38b09bd..6e57c36 100644 --- a/encode.php +++ b/encode.php @@ -2,30 +2,37 @@ # Copyright (C) 2005 Jason Woofenden # -# This file is part of wfpl. -# -# wfpl is free software; you can redistribute it and/or modify it under the -# terms of the GNU Lesser General Public License as published by the Free -# Software Foundation; either version 2.1 of the License, or (at your option) -# any later version. -# -# wfpl is distributed in the hope that it will be useful, but WITHOUT ANY -# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS -# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for -# more details. -# -# You should have received a copy of the GNU Lesser General Public License -# along with wfpl; if not, write to the Free Software Foundation, Inc., 51 -# Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . # This file contains basic encodings. These are used by the encoder. You can -# specify any template tag to be encoded with this syntax: ~variable.encoding~ +# specify any template tag to be encoded with this syntax: ~variable encoding~ # -# this example:

~foo.html~

+# this example:

~foo html~

# will encode foo (using enc_html()) before displaying it, so that characters # such as < will display properly. +function enc_cap($str) { + $str = ucfirst($str); + return $str; +} + +function enc_jsdq($str) { + $str = enc_sql($str); + $str = str_replace("\n", "\\n", $str); + return str_replace("\r", "\\r", $str); +} # encode for putting within double-quotes in SQL function enc_sql($str) { @@ -36,7 +43,7 @@ function enc_sql($str) { # Encode for output in html. does nothing with whitespace # -# Example:

~foo.html~

+# Example:

~foo html~

function enc_html($str) { $str = str_replace('&', '&', $str); $str = str_replace('<', '<', $str); @@ -44,10 +51,48 @@ function enc_html($str) { return $str; } +# Encode for output in html. Convert newlines to
+# +# Example:

~foo htmlbr~

+function enc_htmlbr($str) { + $str = enc_html($str); + $str = str_replace("\n", "
\n", $str); + return $str; +} + +# Encode for output in html. Preserves newlines and indentation by converting +# newlines to
and spaces at the begining of lines to    +# +# Example:

~foo htmlbrtab~

+function enc_htmlbrtab($str) { + $str = enc_htmlbr($str); + $space_to_nbsp = create_function('$matches', 'return str_repeat(\' \', strlen($matches[0]) * 2);'); + $str = preg_replace_callback("|^ *|m", $space_to_nbsp, $str); + return $str; +} + +# Encode for output in html. Spaces converted to   and \n to
+# +# Example: +function enc_htmlbrnbsp($str) { + $str = enc_htmlbr($str); + $str = str_replace(' ', ' ', $str); + return $str; +} + +# Encode for output in html. Spaces converted to   +# +# Example: +function enc_htmlnbsp($str) { + $str = enc_html($str); + $str = str_replace(' ', ' ', $str); + return $str; +} + # HTML attribute. # -# Example: +# Example: function enc_attr($str) { $str = str_replace('&', '&', $str); $str = str_replace('"', '"', $str); @@ -56,24 +101,43 @@ function enc_attr($str) { # URI agument value. # -# Example: http://example.com?foo=~foo.url_val~ +# Example: http://example.com?foo=~foo url_val~ function enc_url_val($str) { return rawurlencode($str); } +# FIXME +function enc_url_path($str) { + $str = rawurlencode($str); + $str = str_replace('%2F', '/', $str); + return $str; +} + + # This is a hack to work around html's stupid syntax for checkboxes. # # Place the template marker just before a " somewhere. # -# Example: +# Example: function enc_checked($str) { - if($str == 'Yes') { + if($str && $str !== 'No' && $str !== 'False' && $str !== 'false') { return '" checked="checked'; } else { return ''; } } +# normally, checkboxes values from get/post to 0 or 1, and stored in the database this way. enc_yesno() can be used in your templates to display this as "Yes" or "No". +# Example template: Subscribe to mailing list?: ~subscribe yesno~ +function enc_yesno($str) { + if($str && $str !== 'No' && $str !== 'False' && $str !== 'false') { + return 'Yes'; + } else { + return 'No'; + } +} + + # add a tab at the begining of each non-empty line function enc_tab($str) { $lines = explode("\n", $str); @@ -93,43 +157,65 @@ function enc_upper($str) { return strtoupper($str); } +# pass date in the form 2008-05-23 +# ercodes date as 05/23/2008 +function enc_mmddyyyy($yyyy_mm_dd) { + if($yyyy_mm_dd == '') { + return ''; + } + if(strlen($yyyy_mm_dd) != 10) { + return date('m/d/Y'); + } + return substr($yyyy_mm_dd, 5, 2) . '/' . substr($yyyy_mm_dd, 8, 2) . '/' . substr($yyyy_mm_dd, 0, 4); +} -# display