| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * CodeIgniter | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  |  * An open source application development framework for PHP | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  |  * This content is released under the MIT License (MIT) | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2021-11-07 03:05:55 +08:00
										 |  |  |  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | 
					
						
							|  |  |  |  * of this software and associated documentation files (the "Software"), to deal | 
					
						
							|  |  |  |  * in the Software without restriction, including without limitation the rights | 
					
						
							|  |  |  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | 
					
						
							|  |  |  |  * copies of the Software, and to permit persons to whom the Software is | 
					
						
							|  |  |  |  * furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The above copyright notice and this permission notice shall be included in | 
					
						
							|  |  |  |  * all copies or substantial portions of the Software. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
					
						
							|  |  |  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | 
					
						
							|  |  |  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
					
						
							|  |  |  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | 
					
						
							|  |  |  |  * THE SOFTWARE. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package	CodeIgniter | 
					
						
							|  |  |  |  * @author	EllisLab Dev Team | 
					
						
							|  |  |  |  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | 
					
						
							| 
									
										
										
										
											2021-11-07 03:05:55 +08:00
										 |  |  |  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | 
					
						
							|  |  |  |  * @license	https://opensource.org/licenses/MIT	MIT License | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  |  * @link	https://codeigniter.com | 
					
						
							|  |  |  |  * @since	Version 1.0.0 | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  |  * @filesource | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | defined('BASEPATH') OR exit('No direct script access allowed'); | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * CodeIgniter Inflector Helpers | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package		CodeIgniter | 
					
						
							|  |  |  |  * @subpackage	Helpers | 
					
						
							|  |  |  |  * @category	Helpers | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  |  * @author		EllisLab Dev Team | 
					
						
							| 
									
										
										
										
											2021-11-07 03:05:55 +08:00
										 |  |  |  * @link		https://codeigniter.com/userguide3/helpers/inflector_helper.html | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // --------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ( ! function_exists('singular')) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Singular | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Takes a plural word and makes it singular | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param	string	$str	Input string | 
					
						
							|  |  |  | 	 * @return	string | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	function singular($str) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 		$result = strval($str); | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-07 03:05:55 +08:00
										 |  |  | 		if ( ! word_is_countable($result)) | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 			return $result; | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 		$singular_rules = array( | 
					
						
							|  |  |  | 			'/(matr)ices$/'		=> '\1ix', | 
					
						
							|  |  |  | 			'/(vert|ind)ices$/'	=> '\1ex', | 
					
						
							|  |  |  | 			'/^(ox)en/'		=> '\1', | 
					
						
							|  |  |  | 			'/(alias)es$/'		=> '\1', | 
					
						
							|  |  |  | 			'/([octop|vir])i$/'	=> '\1us', | 
					
						
							|  |  |  | 			'/(cris|ax|test)es$/'	=> '\1is', | 
					
						
							|  |  |  | 			'/(shoe)s$/'		=> '\1', | 
					
						
							|  |  |  | 			'/(o)es$/'		=> '\1', | 
					
						
							|  |  |  | 			'/(bus|campus)es$/'	=> '\1', | 
					
						
							|  |  |  | 			'/([m|l])ice$/'		=> '\1ouse', | 
					
						
							|  |  |  | 			'/(x|ch|ss|sh)es$/'	=> '\1', | 
					
						
							|  |  |  | 			'/(m)ovies$/'		=> '\1\2ovie', | 
					
						
							|  |  |  | 			'/(s)eries$/'		=> '\1\2eries', | 
					
						
							|  |  |  | 			'/([^aeiouy]|qu)ies$/'	=> '\1y', | 
					
						
							|  |  |  | 			'/([lr])ves$/'		=> '\1f', | 
					
						
							|  |  |  | 			'/(tive)s$/'		=> '\1', | 
					
						
							|  |  |  | 			'/(hive)s$/'		=> '\1', | 
					
						
							|  |  |  | 			'/([^f])ves$/'		=> '\1fe', | 
					
						
							|  |  |  | 			'/(^analy)ses$/'	=> '\1sis', | 
					
						
							|  |  |  | 			'/((a)naly|(b)a|(d)iagno|(p)arenthe|(p)rogno|(s)ynop|(t)he)ses$/' => '\1\2sis', | 
					
						
							|  |  |  | 			'/([ti])a$/'		=> '\1um', | 
					
						
							|  |  |  | 			'/(p)eople$/'		=> '\1\2erson', | 
					
						
							|  |  |  | 			'/(m)en$/'		=> '\1an', | 
					
						
							|  |  |  | 			'/(s)tatuses$/'		=> '\1\2tatus', | 
					
						
							|  |  |  | 			'/(c)hildren$/'		=> '\1\2hild', | 
					
						
							|  |  |  | 			'/(n)ews$/'		=> '\1\2ews', | 
					
						
							|  |  |  | 			'/(quiz)zes$/'		=> '\1', | 
					
						
							|  |  |  | 			'/([^us])s$/'		=> '\1' | 
					
						
							|  |  |  | 		); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		foreach ($singular_rules as $rule => $replacement) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if (preg_match($rule, $result)) | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 				$result = preg_replace($rule, $replacement, $result); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 		return $result; | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // --------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ( ! function_exists('plural')) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Plural | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Takes a singular word and makes it plural | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param	string	$str	Input string | 
					
						
							|  |  |  | 	 * @return	string | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	function plural($str) | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 		$result = strval($str); | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-07 03:05:55 +08:00
										 |  |  | 		if ( ! word_is_countable($result)) | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 			return $result; | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		$plural_rules = array( | 
					
						
							|  |  |  | 			'/(quiz)$/'                => '\1zes',      // quizzes
 | 
					
						
							|  |  |  | 			'/^(ox)$/'                 => '\1\2en',     // ox
 | 
					
						
							|  |  |  | 			'/([m|l])ouse$/'           => '\1ice',      // mouse, louse
 | 
					
						
							|  |  |  | 			'/(matr|vert|ind)ix|ex$/'  => '\1ices',     // matrix, vertex, index
 | 
					
						
							|  |  |  | 			'/(x|ch|ss|sh)$/'          => '\1es',       // search, switch, fix, box, process, address
 | 
					
						
							|  |  |  | 			'/([^aeiouy]|qu)y$/'       => '\1ies',      // query, ability, agency
 | 
					
						
							|  |  |  | 			'/(hive)$/'                => '\1s',        // archive, hive
 | 
					
						
							|  |  |  | 			'/(?:([^f])fe|([lr])f)$/'  => '\1\2ves',    // half, safe, wife
 | 
					
						
							|  |  |  | 			'/sis$/'                   => 'ses',        // basis, diagnosis
 | 
					
						
							|  |  |  | 			'/([ti])um$/'              => '\1a',        // datum, medium
 | 
					
						
							|  |  |  | 			'/(p)erson$/'              => '\1eople',    // person, salesperson
 | 
					
						
							|  |  |  | 			'/(m)an$/'                 => '\1en',       // man, woman, spokesman
 | 
					
						
							|  |  |  | 			'/(c)hild$/'               => '\1hildren',  // child
 | 
					
						
							|  |  |  | 			'/(buffal|tomat)o$/'       => '\1\2oes',    // buffalo, tomato
 | 
					
						
							|  |  |  | 			'/(bu|campu)s$/'           => '\1\2ses',    // bus, campus
 | 
					
						
							|  |  |  | 			'/(alias|status|virus)$/'  => '\1es',       // alias
 | 
					
						
							|  |  |  | 			'/(octop)us$/'             => '\1i',        // octopus
 | 
					
						
							|  |  |  | 			'/(ax|cris|test)is$/'      => '\1es',       // axis, crisis
 | 
					
						
							|  |  |  | 			'/s$/'                     => 's',          // no change (compatibility)
 | 
					
						
							|  |  |  | 			'/$/'                      => 's', | 
					
						
							|  |  |  | 		); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		foreach ($plural_rules as $rule => $replacement) | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 			if (preg_match($rule, $result)) | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 				$result = preg_replace($rule, $replacement, $result); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 		return $result; | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // --------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ( ! function_exists('camelize')) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Camelize | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Takes multiple words separated by spaces or underscores and camelizes them | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param	string	$str	Input string | 
					
						
							|  |  |  | 	 * @return	string | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	function camelize($str) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 		return strtolower($str[0]).substr(str_replace(' ', '', ucwords(preg_replace('/[\s_]+/', ' ', $str))), 1); | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // --------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ( ! function_exists('underscore')) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Underscore | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Takes multiple words separated by spaces and underscores them | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param	string	$str	Input string | 
					
						
							|  |  |  | 	 * @return	string | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	function underscore($str) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 		return preg_replace('/[\s]+/', '_', trim(MB_ENABLED ? mb_strtolower($str) : strtolower($str))); | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // --------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ( ! function_exists('humanize')) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Humanize | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Takes multiple words separated by the separator and changes them to spaces | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param	string	$str		Input string | 
					
						
							|  |  |  | 	 * @param 	string	$separator	Input separator | 
					
						
							|  |  |  | 	 * @return	string | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	function humanize($str, $separator = '_') | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 		return ucwords(preg_replace('/['.preg_quote($separator).']+/', ' ', trim(MB_ENABLED ? mb_strtolower($str) : strtolower($str)))); | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | // --------------------------------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2011-04-25 23:24:01 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-07 03:05:55 +08:00
										 |  |  | if ( ! function_exists('word_is_countable')) | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Checks if the given word has a plural version. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param	string	$word	Word to check | 
					
						
							|  |  |  | 	 * @return	bool | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2021-11-07 03:05:55 +08:00
										 |  |  | 	function word_is_countable($word) | 
					
						
							| 
									
										
										
										
											2017-11-07 08:45:06 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		return ! in_array( | 
					
						
							|  |  |  | 			strtolower($word), | 
					
						
							|  |  |  | 			array( | 
					
						
							|  |  |  | 				'audio', | 
					
						
							|  |  |  | 				'bison', | 
					
						
							|  |  |  | 				'chassis', | 
					
						
							|  |  |  | 				'compensation', | 
					
						
							|  |  |  | 				'coreopsis', | 
					
						
							|  |  |  | 				'data', | 
					
						
							|  |  |  | 				'deer', | 
					
						
							|  |  |  | 				'education', | 
					
						
							|  |  |  | 				'emoji', | 
					
						
							|  |  |  | 				'equipment', | 
					
						
							|  |  |  | 				'fish', | 
					
						
							|  |  |  | 				'furniture', | 
					
						
							|  |  |  | 				'gold', | 
					
						
							|  |  |  | 				'information', | 
					
						
							|  |  |  | 				'knowledge', | 
					
						
							|  |  |  | 				'love', | 
					
						
							|  |  |  | 				'rain', | 
					
						
							|  |  |  | 				'money', | 
					
						
							|  |  |  | 				'moose', | 
					
						
							|  |  |  | 				'nutrition', | 
					
						
							|  |  |  | 				'offspring', | 
					
						
							|  |  |  | 				'plankton', | 
					
						
							|  |  |  | 				'pokemon', | 
					
						
							|  |  |  | 				'police', | 
					
						
							|  |  |  | 				'rice', | 
					
						
							|  |  |  | 				'series', | 
					
						
							|  |  |  | 				'sheep', | 
					
						
							|  |  |  | 				'species', | 
					
						
							|  |  |  | 				'swine', | 
					
						
							|  |  |  | 				'traffic', | 
					
						
							|  |  |  | 				'wheat' | 
					
						
							|  |  |  | 			) | 
					
						
							|  |  |  | 		); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-11-07 03:05:55 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // --------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ( ! function_exists('is_countable')) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	function is_countable($word) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		trigger_error('is_countable() is a native PHP function since version 7.3.0; use word_is_countable() instead', E_USER_WARNING); | 
					
						
							|  |  |  | 		return word_is_countable($word); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // ------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ( ! function_exists('ordinal_format')) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Returns the English ordinal numeral for a given number | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param  int    $number | 
					
						
							|  |  |  | 	 * @return string | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	function ordinal_format($number) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if ( ! ctype_digit((string) $number) OR $number < 1) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			return $number; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		$last_digit = array( | 
					
						
							|  |  |  | 			0 => 'th', | 
					
						
							|  |  |  | 			1 => 'st', | 
					
						
							|  |  |  | 			2 => 'nd', | 
					
						
							|  |  |  | 			3 => 'rd', | 
					
						
							|  |  |  | 			4 => 'th', | 
					
						
							|  |  |  | 			5 => 'th', | 
					
						
							|  |  |  | 			6 => 'th', | 
					
						
							|  |  |  | 			7 => 'th', | 
					
						
							|  |  |  | 			8 => 'th', | 
					
						
							|  |  |  | 			9 => 'th' | 
					
						
							|  |  |  | 		); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (($number % 100) >= 11 && ($number % 100) <= 13) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			return $number.'th'; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return $number.$last_digit[$number % 10]; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |