* Andrei Zmievski * Version: 1.4.0 * Copyright: 2001 ispi of Lincoln, Inc. * * This library 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. * * This library 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 this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * You may contact the authors of Smarty by e-mail at: * monte@ispi.net * andrei@ispi.net * * Or, write to: * Monte Ohrt * CTO, ispi * 237 S. 70th suite 220 * Lincoln, NE 68510 * * The latest version of Smarty can be obtained from: * http://www.phpinsider.com * */ /*============================================*\ Inserts handler \*============================================*/ function _smarty_insert_handler($args, $caching, $delimiter) { if ($caching) { $arg_string = serialize($args); return "$delimiter{insert_cache $arg_string}$delimiter"; } else { $function_name = 'insert_'.$args['name']; return $function_name($args); } } /*============================================*\ Modifiers \*============================================*/ function _smarty_mod_handler() { $args = func_get_args(); list($func_name, $map_array) = array_splice($args, 0, 2); $var = $args[0]; if ($map_array && is_array($var)) { foreach ($var as $key => $val) { $args[0] = $val; $var[$key] = call_user_func_array($func_name, $args); } return $var; } else { return call_user_func_array($func_name, $args); } } /*======================================================================*\ Function: smarty_mod_escape Purpose: Escape the string according to escapement type \*======================================================================*/ function smarty_mod_escape($string, $esc_type = 'html') { switch ($esc_type) { case 'html': return htmlspecialchars($string); case 'url': return urlencode($string); default: return $string; } } /*======================================================================*\ Function: smarty_mod_truncate Purpose: Truncate a string to a certain length if necessary, optionally splitting in the middle of a word, and appending the $etc string. \*======================================================================*/ function smarty_mod_truncate($string, $length = 80, $etc = '...', $break_words = false) { if ($length == 0) return ''; if (strlen($string) > $length) { $length -= strlen($etc); $fragment = substr($string, 0, $length+1); if ($break_words) $fragment = substr($fragment, 0, -1); else $fragment = preg_replace('/\s+(\S+)?$/', '', $fragment); return $fragment.$etc; } else return $string; } /*======================================================================*\ Function: smarty_mod_spacify Purpose: add spaces between characters in a string \*======================================================================*/ function smarty_mod_spacify($string, $spacify_char = ' ') { return implode($spacify_char, preg_split('//', $string, -1, PREG_SPLIT_NO_EMPTY)); } /*======================================================================*\ Function: smarty_mod_date_format Purpose: format datestamps via strftime \*======================================================================*/ function smarty_mod_date_format($string, $format="%b %e, %Y") { return strftime($format, smarty_make_timestamp($string)); } /*======================================================================*\ Function: smarty_make_timestamp Purpose: used by other smarty functions to make a timestamp from a string of characters. \*======================================================================*/ function smarty_make_timestamp($string) { $time = strtotime($string); if(is_numeric($time) && $time != -1) return $time; // is mysql timestamp format of YYYYMMDDHHMMSS? if(is_numeric($string) && strlen($string) == 14) { $time = mktime(substr($string,8,2),substr($string,10,2),substr($string,12,2), substr($string,4,2),substr($string,6,2),substr($string,0,4)); return $time; } // can decipher, must be timestamp already? return $string; } /*======================================================================*\ Function: smarty_mod_string_format Purpose: format strings via sprintf \*======================================================================*/ function smarty_mod_string_format($string, $format) { return sprintf($format, $string); } /*======================================================================*\ Function: smarty_mod_replace Purpose: simple search/replace \*======================================================================*/ function smarty_mod_replace($string, $search, $replace) { return str_replace($search, $replace, $string); } /*======================================================================*\ Function: smarty_mod_strip_tags Purpose: strip html tags from text \*======================================================================*/ function smarty_mod_strip_tags($string, $replace_with_space = true) { if ($replace_with_space) return preg_replace('!<[^>]*?>!', ' ', $string); else return strip_tags($string); } /*======================================================================*\ Function: smarty_mod_default Purpose: designate default text for empty variables \*======================================================================*/ function smarty_mod_default($string, $default="") { if(empty($string)) return $default; else return $string; } /*============================================*\ Custom tag functions \*============================================*/ /*======================================================================*\ Function: smarty_func_html_options Purpose: Prints the list of