mirror of
				https://github.com/smarty-php/smarty.git
				synced 2025-10-31 04:11:37 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Smarty plugin
 | |
|  * @package Smarty
 | |
|  * @subpackage plugins
 | |
|  */
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Smarty truncate modifier plugin
 | |
|  *
 | |
|  * Type:     modifier<br>
 | |
|  * Name:     truncate<br>
 | |
|  * Purpose:  Truncate a string to a certain length if necessary,
 | |
|  *           optionally splitting in the middle of a word, and
 | |
|  *           appending the $etc string.
 | |
|  * @link http://smarty.php.net/manual/en/language.modifier.truncate.php
 | |
|  *          truncate (Smarty online manual)
 | |
|  * @param string
 | |
|  * @param integer
 | |
|  * @param string
 | |
|  * @param boolean
 | |
|  * @return string
 | |
|  */
 | |
| function smarty_modifier_truncate($string, $length = 80, $etc = '...',
 | |
|                                   $break_words = false)
 | |
| {
 | |
|     if ($length == 0)
 | |
|         return '';
 | |
| 
 | |
|     if (strlen($string) > $length) {
 | |
|         $length -= strlen($etc);
 | |
|         if (!$break_words)
 | |
|             $string = preg_replace('/\s+?(\S+)?$/', '', substr($string, 0, $length+1));
 | |
|       
 | |
|         return substr($string, 0, $length).$etc;
 | |
|     } else
 | |
|         return $string;
 | |
| }
 | |
| 
 | |
| /* vim: set expandtab: */
 | |
| 
 | |
| ?>
 |