blob: 60607e95c6e89fd537979c24b25efd94df39b461 [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Phil Sturgeon07c1ac82012-03-09 17:03:37 +00005 * An open source application development framework for PHP 5.2.4 or newer
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +02007 * This content is released under the MIT License (MIT)
Andrey Andreeve684bda2012-03-26 13:47:29 +03008 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +02009 * Copyright (c) 2014, British Columbia Institute of Technology
Andrey Andreeve684bda2012-03-26 13:47:29 +030010 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020011 * Permission is hereby granted, free of charge, to any person obtaining a copy
12 * of this software and associated documentation files (the "Software"), to deal
13 * in the Software without restriction, including without limitation the rights
14 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
15 * copies of the Software, and to permit persons to whom the Software is
16 * furnished to do so, subject to the following conditions:
Derek Jonesf4a4bd82011-10-20 12:18:42 -050017 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020018 * The above copyright notice and this permission notice shall be included in
19 * all copies or substantial portions of the Software.
20 *
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
24 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
26 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
27 * THE SOFTWARE.
28 *
29 * @package CodeIgniter
30 * @author EllisLab Dev Team
darwinel871754a2014-02-11 17:34:57 +010031 * @copyright Copyright (c) 2008 - 2014, EllisLab, Inc. (http://ellislab.com/)
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020032 * @copyright Copyright (c) 2014, British Columbia Institute of Technology (http://bcit.ca/)
33 * @license http://opensource.org/licenses/MIT MIT License
34 * @link http://codeigniter.com
35 * @since Version 1.0.0
Derek Allard2067d1a2008-11-13 22:59:24 +000036 * @filesource
37 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020038defined('BASEPATH') OR exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +000039
Derek Allard2067d1a2008-11-13 22:59:24 +000040/**
41 * CodeIgniter String Helpers
42 *
43 * @package CodeIgniter
44 * @subpackage Helpers
45 * @category Helpers
Derek Jonesf4a4bd82011-10-20 12:18:42 -050046 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000047 * @link http://codeigniter.com/user_guide/helpers/string_helper.html
48 */
49
50// ------------------------------------------------------------------------
51
Derek Allard2067d1a2008-11-13 22:59:24 +000052if ( ! function_exists('trim_slashes'))
53{
Timothy Warrenb75faa12012-04-27 12:03:32 -040054 /**
55 * Trim Slashes
56 *
57 * Removes any leading/trailing slashes from a string:
58 *
59 * /this/that/theother/
60 *
61 * becomes:
62 *
63 * this/that/theother
64 *
Andrey Andreevf7c39d62012-11-08 22:01:33 +020065 * @todo Remove in version 3.1+.
66 * @deprecated 3.0.0 This is just an alias for PHP's native trim()
67 *
Timothy Warrenb75faa12012-04-27 12:03:32 -040068 * @param string
69 * @return string
70 */
Derek Allard2067d1a2008-11-13 22:59:24 +000071 function trim_slashes($str)
72 {
Barry Mienydd671972010-10-04 16:33:58 +020073 return trim($str, '/');
Derek Jones1e141922010-03-05 10:24:50 -060074 }
Derek Allard2067d1a2008-11-13 22:59:24 +000075}
Derek Jones1e141922010-03-05 10:24:50 -060076
Derek Allard2067d1a2008-11-13 22:59:24 +000077// ------------------------------------------------------------------------
78
Derek Allard2067d1a2008-11-13 22:59:24 +000079if ( ! function_exists('strip_slashes'))
80{
Timothy Warrenb75faa12012-04-27 12:03:32 -040081 /**
82 * Strip Slashes
83 *
84 * Removes slashes contained in a string or in an array
85 *
86 * @param mixed string or array
87 * @return mixed string or array
88 */
Derek Allard2067d1a2008-11-13 22:59:24 +000089 function strip_slashes($str)
90 {
Andrey Andreev09375d72012-01-19 14:57:46 +020091 if ( ! is_array($str))
Barry Mienydd671972010-10-04 16:33:58 +020092 {
Andrey Andreev4921fed2012-01-07 01:28:07 +020093 return stripslashes($str);
Derek Allard2067d1a2008-11-13 22:59:24 +000094 }
Barry Mienydd671972010-10-04 16:33:58 +020095
Andrey Andreev09375d72012-01-19 14:57:46 +020096 foreach ($str as $key => $val)
Derek Allard2067d1a2008-11-13 22:59:24 +000097 {
Andrey Andreev09375d72012-01-19 14:57:46 +020098 $str[$key] = strip_slashes($val);
Derek Allard2067d1a2008-11-13 22:59:24 +000099 }
100
101 return $str;
102 }
103}
104
105// ------------------------------------------------------------------------
106
Derek Allard2067d1a2008-11-13 22:59:24 +0000107if ( ! function_exists('strip_quotes'))
108{
Timothy Warrenb75faa12012-04-27 12:03:32 -0400109 /**
110 * Strip Quotes
111 *
112 * Removes single and double quotes from a string
113 *
114 * @param string
115 * @return string
116 */
Derek Allard2067d1a2008-11-13 22:59:24 +0000117 function strip_quotes($str)
118 {
119 return str_replace(array('"', "'"), '', $str);
120 }
121}
122
123// ------------------------------------------------------------------------
124
Derek Allard2067d1a2008-11-13 22:59:24 +0000125if ( ! function_exists('quotes_to_entities'))
126{
Timothy Warrenb75faa12012-04-27 12:03:32 -0400127 /**
128 * Quotes to Entities
129 *
130 * Converts single and double quotes to entities
131 *
132 * @param string
133 * @return string
134 */
Derek Allard2067d1a2008-11-13 22:59:24 +0000135 function quotes_to_entities($str)
Barry Mienydd671972010-10-04 16:33:58 +0200136 {
Derek Allard2067d1a2008-11-13 22:59:24 +0000137 return str_replace(array("\'","\"","'",'"'), array("&#39;","&quot;","&#39;","&quot;"), $str);
138 }
139}
140
141// ------------------------------------------------------------------------
Derek Jones1e141922010-03-05 10:24:50 -0600142
Derek Allard2067d1a2008-11-13 22:59:24 +0000143if ( ! function_exists('reduce_double_slashes'))
144{
Timothy Warrenb75faa12012-04-27 12:03:32 -0400145 /**
146 * Reduce Double Slashes
147 *
148 * Converts double slashes in a string to a single slash,
149 * except those found in http://
150 *
151 * http://www.some-site.com//index.php
152 *
153 * becomes:
154 *
155 * http://www.some-site.com/index.php
156 *
157 * @param string
158 * @return string
159 */
Derek Allard2067d1a2008-11-13 22:59:24 +0000160 function reduce_double_slashes($str)
161 {
Andrey Andreev84c3b272012-03-26 21:50:00 +0300162 return preg_replace('#(^|[^:])//+#', '\\1/', $str);
Derek Allard2067d1a2008-11-13 22:59:24 +0000163 }
164}
Derek Jones1e141922010-03-05 10:24:50 -0600165
Derek Allard2067d1a2008-11-13 22:59:24 +0000166// ------------------------------------------------------------------------
167
Derek Allard2067d1a2008-11-13 22:59:24 +0000168if ( ! function_exists('reduce_multiples'))
169{
Timothy Warrenb75faa12012-04-27 12:03:32 -0400170 /**
171 * Reduce Multiples
172 *
173 * Reduces multiple instances of a particular character. Example:
174 *
175 * Fred, Bill,, Joe, Jimmy
176 *
177 * becomes:
178 *
179 * Fred, Bill, Joe, Jimmy
180 *
181 * @param string
182 * @param string the character you wish to reduce
183 * @param bool TRUE/FALSE - whether to trim the character from the beginning/end
184 * @return string
185 */
Derek Allard2067d1a2008-11-13 22:59:24 +0000186 function reduce_multiples($str, $character = ',', $trim = FALSE)
187 {
188 $str = preg_replace('#'.preg_quote($character, '#').'{2,}#', $character, $str);
Andrey Andreev4921fed2012-01-07 01:28:07 +0200189 return ($trim === TRUE) ? trim($str, $character) : $str;
Derek Allard2067d1a2008-11-13 22:59:24 +0000190 }
191}
Barry Mienydd671972010-10-04 16:33:58 +0200192
Derek Allard2067d1a2008-11-13 22:59:24 +0000193// ------------------------------------------------------------------------
194
Derek Allard2067d1a2008-11-13 22:59:24 +0000195if ( ! function_exists('random_string'))
Derek Allard472dd212010-01-23 20:03:27 +0000196{
Timothy Warrenb75faa12012-04-27 12:03:32 -0400197 /**
198 * Create a Random String
199 *
200 * Useful for generating passwords or hashes.
201 *
Olanipekun Femi08dd57c2014-02-07 08:16:48 -0800202 * @param string type of random string. basic, alpha, alnum, numeric, nozero, unique, md5, encrypt and sha1
Timothy Warrenb75faa12012-04-27 12:03:32 -0400203 * @param int number of characters
204 * @return string
205 */
Derek Allard2067d1a2008-11-13 22:59:24 +0000206 function random_string($type = 'alnum', $len = 8)
Barry Mienydd671972010-10-04 16:33:58 +0200207 {
Andrey Andreev4921fed2012-01-07 01:28:07 +0200208 switch ($type)
Derek Allard2067d1a2008-11-13 22:59:24 +0000209 {
Andrey Andreev1a361202012-03-26 22:08:49 +0300210 case 'basic':
211 return mt_rand();
Andrey Andreev4921fed2012-01-07 01:28:07 +0200212 case 'alnum':
213 case 'numeric':
214 case 'nozero':
215 case 'alpha':
216 switch ($type)
217 {
Andrey Andreevcb324bd2012-01-08 07:06:35 +0200218 case 'alpha':
219 $pool = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
Andrey Andreev4921fed2012-01-07 01:28:07 +0200220 break;
Andrey Andreevcb324bd2012-01-08 07:06:35 +0200221 case 'alnum':
222 $pool = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
Andrey Andreev4921fed2012-01-07 01:28:07 +0200223 break;
Andrey Andreevcb324bd2012-01-08 07:06:35 +0200224 case 'numeric':
225 $pool = '0123456789';
Andrey Andreev4921fed2012-01-07 01:28:07 +0200226 break;
Andrey Andreevcb324bd2012-01-08 07:06:35 +0200227 case 'nozero':
228 $pool = '123456789';
Andrey Andreev4921fed2012-01-07 01:28:07 +0200229 break;
230 }
Andrey Andreev75124a52012-03-13 12:47:58 +0200231 return substr(str_shuffle(str_repeat($pool, ceil($len / strlen($pool)))), 0, $len);
Andrey Andreev442682e2012-11-08 22:52:12 +0200232 case 'unique': // todo: remove in 3.1+
Andrey Andreev1a361202012-03-26 22:08:49 +0300233 case 'md5':
234 return md5(uniqid(mt_rand()));
Andrey Andreev442682e2012-11-08 22:52:12 +0200235 case 'encrypt': // todo: remove in 3.1+
Andrey Andreev4921fed2012-01-07 01:28:07 +0200236 case 'sha1':
Andrey Andreev1a361202012-03-26 22:08:49 +0300237 return sha1(uniqid(mt_rand(), TRUE));
Derek Allard2067d1a2008-11-13 22:59:24 +0000238 }
239 }
240}
Derek Jones1e141922010-03-05 10:24:50 -0600241
Derek Allard2067d1a2008-11-13 22:59:24 +0000242// ------------------------------------------------------------------------
243
Andrey Andreev84c3b272012-03-26 21:50:00 +0300244if ( ! function_exists('increment_string'))
Phil Sturgeond8ef6302011-08-14 12:10:55 -0600245{
Timothy Warrenb75faa12012-04-27 12:03:32 -0400246 /**
247 * Add's _1 to a string or increment the ending number to allow _2, _3, etc
248 *
249 * @param string required
250 * @param string What should the duplicate number be appended with
251 * @param string Which number should be used for the first dupe increment
252 * @return string
253 */
Andrey Andreev84c3b272012-03-26 21:50:00 +0300254 function increment_string($str, $separator = '_', $first = 1)
255 {
256 preg_match('/(.+)'.$separator.'([0-9]+)$/', $str, $match);
Andrey Andreev84c3b272012-03-26 21:50:00 +0300257 return isset($match[2]) ? $match[1].$separator.($match[2] + 1) : $str.$separator.$first;
258 }
Phil Sturgeond8ef6302011-08-14 12:10:55 -0600259}
260
261// ------------------------------------------------------------------------
262
Derek Allard2067d1a2008-11-13 22:59:24 +0000263if ( ! function_exists('alternator'))
264{
Timothy Warrenb75faa12012-04-27 12:03:32 -0400265 /**
266 * Alternator
267 *
268 * Allows strings to be alternated. See docs...
269 *
270 * @param string (as many parameters as needed)
271 * @return string
272 */
273 function alternator($args)
Derek Allard2067d1a2008-11-13 22:59:24 +0000274 {
Barry Mienydd671972010-10-04 16:33:58 +0200275 static $i;
Derek Allard2067d1a2008-11-13 22:59:24 +0000276
Alex Bilbie773ccc32012-06-02 11:11:08 +0100277 if (func_num_args() === 0)
Derek Allard2067d1a2008-11-13 22:59:24 +0000278 {
279 $i = 0;
280 return '';
281 }
282 $args = func_get_args();
283 return $args[($i++ % count($args))];
284 }
285}
286
287// ------------------------------------------------------------------------
288
Derek Allard2067d1a2008-11-13 22:59:24 +0000289if ( ! function_exists('repeater'))
290{
Timothy Warrenb75faa12012-04-27 12:03:32 -0400291 /**
292 * Repeater function
293 *
Andrey Andreev60826db2012-10-27 14:45:23 +0300294 * @todo Remove in version 3.1+.
295 * @deprecated 3.0.0 This is just an alias for PHP's native str_repeat()
296 *
297 * @param string $data String to repeat
298 * @param int $num Number of repeats
Timothy Warrenb75faa12012-04-27 12:03:32 -0400299 * @return string
300 */
Derek Allard2067d1a2008-11-13 22:59:24 +0000301 function repeater($data, $num = 1)
302 {
Andrey Andreev84c3b272012-03-26 21:50:00 +0300303 return ($num > 0) ? str_repeat($data, $num) : '';
Barry Mienydd671972010-10-04 16:33:58 +0200304 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000305}
306
Derek Allard2067d1a2008-11-13 22:59:24 +0000307/* End of file string_helper.php */
iolufemic7d82d82014-02-09 22:39:22 +0100308/* Location: ./system/helpers/string_helper.php */