ILIAS  release_5-1 Revision 5.0.0-5477-g43f3e3fab5f
ilStr Class Reference

Multi byte sensitive string functions. More...

+ Collaboration diagram for ilStr:

Public Member Functions

 normalizeUtf8String ($a_str)
 Normalize UTF8 string. More...
 

Static Public Member Functions

static subStr ($a_str, $a_start, $a_length=NULL)
 
static strPos ($a_haystack, $a_needle, $a_offset=NULL)
 
static strIPos ($a_haystack, $a_needle, $a_offset=NULL)
 
static strLen ($a_string)
 
static strToLower ($a_string)
 
static strToUpper ($a_string)
 
static strCmp ($a, $b)
 Compare two strings. More...
 
static shortenText ($a_string, $a_start_pos, $a_num_bytes, $a_encoding='UTF-8')
 Shorten text to the given number of bytes. More...
 
static isUtf8 ($a_str)
 Check whether string is utf-8. More...
 
static strPosAll ($a_haystack, $a_needle)
 Get all positions of a string. More...
 
static replaceFirsOccurence ($a_old, $a_new, $a_str)
 Replaces the first occurence of $a_old in $a_str with $a_new. More...
 
static convertUpperCamelCaseToUnderscoreCase ($value)
 Convert a value given in camel case conversion to underscore case conversion (e.g. More...
 
static getBytesForString ($a_str)
 Return string as byte array Note: Use this for debugging purposes only. More...
 

Detailed Description

Multi byte sensitive string functions.

Author
Alex Killing alex..nosp@m.kill.nosp@m.ing@g.nosp@m.mx.d.nosp@m.e
Helmut Schottmüller helmu.nosp@m.t.sc.nosp@m.hottm.nosp@m.uell.nosp@m.er@ma.nosp@m.c.co.nosp@m.m
Version
$Id$

Definition at line 13 of file class.ilStr.php.

Member Function Documentation

◆ convertUpperCamelCaseToUnderscoreCase()

static ilStr::convertUpperCamelCaseToUnderscoreCase (   $value)
static

Convert a value given in camel case conversion to underscore case conversion (e.g.

MyClass to my_class)

Parameters
string$valueValue in lower camel case conversion
Returns
string The value in underscore case conversion

Definition at line 230 of file class.ilStr.php.

230 {
231 return preg_replace('/(^|[a-z])([A-Z])/e', 'strtolower(strlen("\\1") ? "\\1_\\2" : "\\2")', $value);
232 }

Referenced by ilAbstractBuddySystemRelationStateButtonRenderer\__construct(), and ilMailSearchCoursesGUI\showMembers().

+ Here is the caller graph for this function:

◆ getBytesForString()

static ilStr::getBytesForString (   $a_str)
static

Return string as byte array Note: Use this for debugging purposes only.

If strlen is overwritten by mb_ functions (PHP config) this will return not all characters

Parameters
string$a_strstring
Returns
array array of bytes

Definition at line 242 of file class.ilStr.php.

243 {
244 $bytes = array();
245 for($i = 0; $i < strlen($a_str); $i++)
246 {
247 $bytes[] = ord($a_str[$i]);
248 }
249 return $bytes;
250 }

Referenced by ilObjFile\createProperties().

+ Here is the caller graph for this function:

◆ isUtf8()

static ilStr::isUtf8 (   $a_str)
static

Check whether string is utf-8.

Definition at line 154 of file class.ilStr.php.

155 {
156 if (function_exists("mb_detect_encoding"))
157 {
158 if (mb_detect_encoding($a_str, "UTF-8", true) == "UTF-8")
159 {
160 return true;
161 }
162 }
163 else
164 {
165 // copied from http://www.php.net/manual/en/function.mb-detect-encoding.php
166 $c=0; $b=0;
167 $bits=0;
168 $len=strlen($str);
169 for($i=0; $i<$len; $i++){
170 $c=ord($str[$i]);
171 if($c > 128){
172 if(($c >= 254)) return false;
173 elseif($c >= 252) $bits=6;
174 elseif($c >= 248) $bits=5;
175 elseif($c >= 240) $bits=4;
176 elseif($c >= 224) $bits=3;
177 elseif($c >= 192) $bits=2;
178 else return false;
179 if(($i+$bits) > $len) return false;
180 while($bits > 1){
181 $i++;
182 $b=ord($str[$i]);
183 if($b < 128 || $b > 191) return false;
184 $bits--;
185 }
186 }
187 }
188 return true;
189 }
190 return false;
191 }
if(!file_exists(getcwd().'/ilias.ini.php')) if(isset( $_GET["client_id"]))
registration confirmation script for ilias
Definition: confirmReg.php:20
if(PHP_SAPI=='cli') else
while(!file_exists( 'ilias.ini.php'))
Definition: latex.php:4

Referenced by ilObjLanguage\check(), ilDataCollectionRecordListGUI\getImportFieldsFromTitles(), and ilDataCollectionRecordListGUI\importRecords().

+ Here is the caller graph for this function:

◆ normalizeUtf8String()

ilStr::normalizeUtf8String (   $a_str)

Normalize UTF8 string.

Parameters
string$a_strstring
Returns
string

Definition at line 258 of file class.ilStr.php.

259 {
260 include_once("./include/Unicode/UtfNormal.php");
261 return UtfNormal::toNFC($a_str);
262 }
toNFC( $string)
Convert a UTF-8 string to normal form C, canonical composition.
Definition: UtfNormal.php:157

References UtfNormal\toNFC().

Referenced by ilDragDropFileInputGUI\checkInput(), and ilFileInputGUI\checkInput().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ replaceFirsOccurence()

static ilStr::replaceFirsOccurence (   $a_old,
  $a_new,
  $a_str 
)
static

Replaces the first occurence of $a_old in $a_str with $a_new.

Definition at line 216 of file class.ilStr.php.

217 {
218 if (is_int(strpos($a_str, $a_old)))
219 {
220 $a_str = substr_replace ($a_str, $a_new, strpos($a_str, $a_old), strlen($a_old));
221 }
222 return $a_str;
223 }

Referenced by ilPageObjectGUI\insertPageToc().

+ Here is the caller graph for this function:

◆ shortenText()

static ilStr::shortenText (   $a_string,
  $a_start_pos,
  $a_num_bytes,
  $a_encoding = 'UTF-8' 
)
static

Shorten text to the given number of bytes.

If the character is cutted within a character the invalid character will be shortened, too.

E.g: shortenText('€€€',4) will return '€'

Parameters
string$a_string
int$a_start_pos
int$a_num_bytes
string$a_encoding[optional]
Returns
string

Definition at line 146 of file class.ilStr.php.

147 {
148 return mb_strcut($a_string, $a_start_pos, $a_num_bytes, $a_encoding);
149 }

Referenced by ilPageObject\truncateHTML().

+ Here is the caller graph for this function:

◆ strCmp()

static ilStr::strCmp (   $a,
  $b 
)
static

Compare two strings.

Definition at line 119 of file class.ilStr.php.

120 {
121 global $ilCollator;
122
123 if (is_object($ilCollator))
124 {
125 return ($ilCollator->compare(ilStr::strToUpper($a), ilStr::strToUpper($b)) > 0);
126 }
127 else
128 {
129 return (strcoll(ilStr::strToUpper($a), ilStr::strToUpper($b)) > 0);
130 }
131 }
static strToUpper($a_string)

References strToUpper().

Referenced by ilUtil\sort_func().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ strIPos()

static ilStr::strIPos (   $a_haystack,
  $a_needle,
  $a_offset = NULL 
)
static

Definition at line 46 of file class.ilStr.php.

47 {
48 if (function_exists("mb_stripos"))
49 {
50 return mb_stripos($a_haystack, $a_needle, $a_offset, "UTF-8");
51 }
52 else
53 {
54 return stripos($a_haystack, $a_needle, $a_offset);
55 }
56 }

Referenced by ilPCParagraph\linkTermsInDom().

+ Here is the caller graph for this function:

◆ strLen()

static ilStr::strLen (   $a_string)
static

◆ strPos()

static ilStr::strPos (   $a_haystack,
  $a_needle,
  $a_offset = NULL 
)
static

Definition at line 34 of file class.ilStr.php.

35 {
36 if (function_exists("mb_strpos"))
37 {
38 return mb_strpos($a_haystack, $a_needle, $a_offset, "UTF-8");
39 }
40 else
41 {
42 return strpos($a_haystack, $a_needle, $a_offset);
43 }
44 }

Referenced by assTextQuestion\isKeywordMatching(), ilUtil\shortenText(), assOrderingHorizontal\splitAndTrimOrderElementText(), and ilMailAutoCompleteSentMailsRecipientsProvider\valid().

+ Here is the caller graph for this function:

◆ strPosAll()

static ilStr::strPosAll (   $a_haystack,
  $a_needle 
)
static

Get all positions of a string.

Parameters
stringthe string to search in
stringthe string to search for
Returns
array all occurences of needle in haystack

Definition at line 201 of file class.ilStr.php.

202 {
203 $positions = array();
204 $cpos = 0;
205 while(is_int($pos = strpos($a_haystack, $a_needle, $cpos)))
206 {
207 $positions[] = $pos;
208 $cpos = $pos+1;
209 }
210 return $positions;
211 }

Referenced by ilPageObjectGUI\insertPageToc().

+ Here is the caller graph for this function:

◆ strToLower()

static ilStr::strToLower (   $a_string)
static

Definition at line 91 of file class.ilStr.php.

92 {
93 if (function_exists("mb_strtolower"))
94 {
95 return mb_strtolower($a_string, "UTF-8");
96 }
97 else
98 {
99 return strtolower($a_string);
100 }
101 }

Referenced by ilTree\getNodePathForTitlePath(), assClozeTest\getTextgapPoints(), assTextSubset\isAnswerCorrect(), assTextQuestion\isKeywordMatching(), and ilMailAutoCompleteSentMailsRecipientsProvider\valid().

+ Here is the caller graph for this function:

◆ strToUpper()

static ilStr::strToUpper (   $a_string)
static

Definition at line 103 of file class.ilStr.php.

104 {
105 $a_string = (string) $a_string;
106 if (function_exists("mb_strtoupper"))
107 {
108 return mb_strtoupper($a_string, "UTF-8");
109 }
110 else
111 {
112 return strtoupper($a_string);
113 }
114 }

Referenced by ilUtil\sort_func(), and strCmp().

+ Here is the caller graph for this function:

◆ subStr()

static ilStr::subStr (   $a_str,
  $a_start,
  $a_length = NULL 
)
static

Definition at line 15 of file class.ilStr.php.

16 {
17 if (function_exists("mb_substr"))
18 {
19 // bug in PHP < 5.4.12: null is not supported as length (if encoding given)
20 // https://github.com/php/php-src/pull/133
21 if ($a_length === null)
22 {
23 $a_length = mb_strlen($a_str, "UTF-8");
24 }
25
26 return mb_substr($a_str, $a_start, $a_length, "UTF-8");
27 }
28 else
29 {
30 return substr($a_str, $a_start, $a_length);
31 }
32 }

Referenced by ilObjQuestionPool\_getFullPathToQpl(), ilSCORMCertificateAdapter\addAdditionalFormElements(), ilICalWriter\addLine(), ilPCParagraph\linkTermsInDom(), ilObjForumAccess\prepareMessageForLists(), ilUtil\shortenText(), ilUtil\shortenWords(), and ilObjBibliographic\writeSourcefileEntriesToDb().

+ Here is the caller graph for this function:

The documentation for this class was generated from the following file: