forked from moodle/moodle
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
MDL-53896 core: Document Html2Text run-time overrides
- Loading branch information
1 parent
e0c901d
commit cd6041b
Showing
2 changed files
with
107 additions
and
27 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -15,44 +15,119 @@ | |
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. | ||
|
||
/** | ||
* Wrapper for Html2Text | ||
* Run time overrides for Html2Text | ||
* | ||
* This wrapper allows us to modify the upstream library without hacking it too much. | ||
* This allows us to monkey patch the mb_* functions used in Html2Text to use Moodle's core_text functionality. | ||
* | ||
* @package core | ||
* @copyright 2015 Andrew Nicols <[email protected]> | ||
* @copyright 2016 Andrew Nicols <[email protected]> | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
|
||
namespace Html2Text { | ||
function mb_internal_encoding($encoding = null) { | ||
static $internalencoding = 'utf-8'; | ||
if ($encoding !== null) { | ||
$internalencoding = $encoding; | ||
return true; | ||
} else { | ||
return $internalencoding; | ||
} | ||
namespace Html2Text; | ||
|
||
/** | ||
* Set the encoding to be used by our monkey patched mb_ functions. | ||
* | ||
* When called with $encoding !== null, we set the static $intenalencoding | ||
* variable, which is used for subsequent calls. | ||
* | ||
* When called with no value for $encoding, we return the previously defined | ||
* $internalencoding. | ||
* | ||
* This is necessary as we need to maintain the state of mb_internal_encoding | ||
* across calls to other mb_* functions. Check how it is used in the other mb_* | ||
* functions defined here - if no encoding is provided we fallback to what was | ||
* set here, otherwise we used the given encoding. | ||
* | ||
* @staticvar string $internalencoding The encoding to be used across mb_* calls. | ||
* @param string $encoding When given, sets $internalencoding | ||
* @return mixed | ||
*/ | ||
function mb_internal_encoding($encoding = null) { | ||
static $internalencoding = 'utf-8'; | ||
if ($encoding !== null) { | ||
$internalencoding = $encoding; | ||
return true; | ||
} else { | ||
return $internalencoding; | ||
} | ||
} | ||
|
||
function mb_substr($str, $start, $length, $encoding = null) { | ||
if ($encoding === null) { | ||
$encoding = mb_internal_encoding(); | ||
} | ||
return \core_text::substr($str, $start, $length, $encoding); | ||
/** | ||
* Performs a multi-byte safe substr() operation based on number of characters. | ||
* Position is counted from the beginning of str. First character's position is | ||
* 0. Second character position is 1, and so on. | ||
* | ||
* @param string $str The string to extract the substring from. | ||
* @param int $start If start is non-negative, the returned string will | ||
* start at the start'th position in string, counting | ||
* from zero. For instance, in the string 'abcdef', | ||
* the character at position 0 is 'a', the character | ||
* at position 2 is 'c', and so forth. | ||
* @param int $length Maximum number of characters to use from str. If | ||
* omitted or NULL is passed, extract all characters | ||
* to the end of the string. | ||
* @param string $encoding The encoding parameter is the character encoding. | ||
* If it is omitted, the internal character encoding | ||
* value will be used. | ||
* | ||
* @return string The portion of str specified by the start and length parameters. | ||
*/ | ||
function mb_substr($str, $start, $length = null, $encoding = null) { | ||
if ($encoding === null) { | ||
$encoding = mb_internal_encoding(); | ||
} | ||
return \core_text::substr($str, $start, $length, $encoding); | ||
} | ||
|
||
function mb_strlen($str, $encoding = null) { | ||
if ($encoding === null) { | ||
$encoding = mb_internal_encoding(); | ||
} | ||
return \core_text::strlen($str, $encoding); | ||
/** | ||
* Gets the length of a string. | ||
* | ||
* @param string $str The string being checked for length. | ||
* @param string $encoding The encoding parameter is the character encoding. | ||
* If it is omitted, the internal character encoding | ||
* value will be used. | ||
* | ||
* @return int The number of characters in str having character encoding $encoding. | ||
* A multibyte character is counted as 1. | ||
*/ | ||
function mb_strlen($str, $encoding = null) { | ||
if ($encoding === null) { | ||
$encoding = mb_internal_encoding(); | ||
} | ||
return \core_text::strlen($str, $encoding); | ||
} | ||
|
||
/** | ||
* Returns $str with all alphabetic chatacters converted to lowercase. | ||
* | ||
* @param string $str The string being lowercased. | ||
* @param string $encoding The encoding parameter is the character encoding. | ||
* If it is omitted, the internal character encoding | ||
* value will be used. | ||
* | ||
* @return string The string with all alphabetic characters converted to lowercase. | ||
*/ | ||
function mb_strtolower($str, $encoding = null) { | ||
if ($encoding === null) { | ||
$encoding = mb_internal_encoding(); | ||
} | ||
return \core_text::strtolower($str, $encoding); | ||
} | ||
|
||
function mb_strtolower($str, $encoding = null) { | ||
if ($encoding === null) { | ||
$encoding = mb_internal_encoding(); | ||
} | ||
return \core_text::strtolower($str, $encoding); | ||
/** | ||
* | ||
* @param string The string being uppercased | ||
* @param string $encoding The encoding parameter is the character encoding. | ||
* If it is omitted, the internal character encoding | ||
* value will be used. | ||
* | ||
* @return string The string with all alphabetic characters converted to uppercase. | ||
*/ | ||
function mb_strtoupper($str, $encoding = null) { | ||
if ($encoding === null) { | ||
$encoding = mb_internal_encoding(); | ||
} | ||
return \core_text::strtoupper($str, $encoding); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters