You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
82 lines
2.2 KiB
82 lines
2.2 KiB
1 year ago
|
<?php
|
||
|
/**
|
||
|
* li₃: the most RAD framework for PHP (http://li3.me)
|
||
|
*
|
||
|
* Copyright 2012, Union of RAD. All rights reserved. This source
|
||
|
* code is distributed under the terms of the BSD 3-Clause License.
|
||
|
* The full license text can be found in the LICENSE.txt file.
|
||
|
*/
|
||
|
|
||
|
namespace lithium\g11n\multibyte\adapter;
|
||
|
|
||
|
/**
|
||
|
* The `Mbstring` class is an adapter which uses certain string functions from
|
||
|
* `ext/mbstring`. You will need to have the extension installed to use this adapter.
|
||
|
*
|
||
|
* No known limitations affecting used functionality. Silently strips
|
||
|
* out badly formed UTF-8 sequences.
|
||
|
*
|
||
|
* @link http://php.net/book.mbstring.php
|
||
|
*/
|
||
|
class Mbstring extends \lithium\core\ObjectDeprecated {
|
||
|
|
||
|
/**
|
||
|
* Determines if this adapter is enabled by checking if the `mbstring` extension is loaded.
|
||
|
*
|
||
|
* @return boolean Returns `true` if enabled, otherwise `false`.
|
||
|
*/
|
||
|
public static function enabled() {
|
||
|
return extension_loaded('mbstring');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Here used as a multibyte enabled equivalent of `strlen()`.
|
||
|
*
|
||
|
* @link http://php.net/function.mb-strlen.php
|
||
|
* @param string $string
|
||
|
* @return integer
|
||
|
*/
|
||
|
public function strlen($string) {
|
||
|
return mb_strlen($string, 'UTF-8');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Here used as a multibyte enabled equivalent of `strpos()`.
|
||
|
*
|
||
|
* @link http://php.net/function.mb-strpos.php
|
||
|
* @param string $haystack
|
||
|
* @param string $needle
|
||
|
* @param integer $offset
|
||
|
* @return integer|boolean
|
||
|
*/
|
||
|
public function strpos($haystack, $needle, $offset) {
|
||
|
return mb_strpos($haystack, $needle, $offset, 'UTF-8');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Here used as a multibyte enabled equivalent of `strrpos()`.
|
||
|
*
|
||
|
* @link http://php.net/function.mb-strpos.php
|
||
|
* @param string $haystack
|
||
|
* @param string $needle
|
||
|
* @return integer|boolean
|
||
|
*/
|
||
|
public function strrpos($haystack, $needle) {
|
||
|
return mb_strrpos($haystack, $needle, 0, 'UTF-8');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Here used as a multibyte enabled equivalent of `substr()`.
|
||
|
*
|
||
|
* @link http://php.net/function.mb-substr.php
|
||
|
* @param string $string
|
||
|
* @param integer $start
|
||
|
* @param integer $length
|
||
|
* @return string|boolean
|
||
|
*/
|
||
|
public function substr($string, $start, $length) {
|
||
|
return mb_substr($string, $start, $length, 'UTF-8');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
?>
|