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

<?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');
}
}
?>