2013-07-14 22:15:45 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Smarty plugin
|
|
|
|
*
|
2014-06-06 02:40:04 +00:00
|
|
|
* @package Smarty
|
2013-07-14 22:15:45 +00:00
|
|
|
* @subpackage PluginsModifierCompiler
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* Smarty count_words modifier plugin
|
2017-11-11 07:11:33 +01:00
|
|
|
* Type: modifier
|
|
|
|
* Name: count_words
|
2013-07-14 22:15:45 +00:00
|
|
|
* Purpose: count the number of words in a text
|
|
|
|
*
|
2021-10-13 12:15:17 +02:00
|
|
|
* @link https://www.smarty.net/manual/en/language.modifier.count.words.php count_words (Smarty online manual)
|
2013-07-14 22:15:45 +00:00
|
|
|
* @author Uwe Tews
|
2014-06-06 02:40:04 +00:00
|
|
|
*
|
2013-07-14 22:15:45 +00:00
|
|
|
* @param array $params parameters
|
2014-06-06 02:40:04 +00:00
|
|
|
*
|
2013-07-14 22:15:45 +00:00
|
|
|
* @return string with compiled code
|
2014-06-06 02:40:04 +00:00
|
|
|
*/
|
|
|
|
function smarty_modifiercompiler_count_words($params)
|
2013-07-14 22:15:45 +00:00
|
|
|
{
|
|
|
|
if (Smarty::$_MBSTRING) {
|
|
|
|
// return 'preg_match_all(\'#[\w\pL]+#' . Smarty::$_UTF8_MODIFIER . '\', ' . $params[0] . ', $tmp)';
|
|
|
|
// expression taken from http://de.php.net/manual/en/function.str-word-count.php#85592
|
2016-02-09 01:27:15 +01:00
|
|
|
return 'preg_match_all(\'/\p{L}[\p{L}\p{Mn}\p{Pd}\\\'\x{2019}]*/' . Smarty::$_UTF8_MODIFIER . '\', ' .
|
|
|
|
$params[ 0 ] . ', $tmp)';
|
2013-07-14 22:15:45 +00:00
|
|
|
}
|
|
|
|
// no MBString fallback
|
2023-01-16 18:24:23 -05:00
|
|
|
return 'str_word_count((string) ' . $params[ 0 ] . ')';
|
2013-07-14 22:15:45 +00:00
|
|
|
}
|