Zeile 3 | Zeile 3 |
---|
* MyBB 1.2 * Copyright � 2006 MyBB Group, All Rights Reserved *
|
* MyBB 1.2 * Copyright � 2006 MyBB Group, All Rights Reserved *
|
* Website: http://www.mybboard.com * License: http://www.mybboard.com/eula.html
| * Website: http://www.mybboard.net * License: http://www.mybboard.net/eula.html
|
*
|
*
|
* $Id: class_parser.php 2271 2006-09-27 02:45:07Z Tikitiki $
| * $Id: class_parser.php 3531 2007-12-02 01:21:43Z chris $
|
*/
/*
| */
/*
|
Zeile 68 | Zeile 68 |
---|
*/ function parse_message($message, $options=array()) {
|
*/ function parse_message($message, $options=array()) {
|
global $plugins, $mybb;
| global $plugins, $mybb, $lang;
|
// Set base URL for parsing smilies $this->base_url = $mybb->settings['bburl'];
if($this->base_url != "") {
|
// Set base URL for parsing smilies $this->base_url = $mybb->settings['bburl'];
if($this->base_url != "") {
|
if(my_substr($this->base_url, strlen($this->base_url) -1) != "/")
| if(my_substr($this->base_url, my_strlen($this->base_url) -1) != "/")
|
{ $this->base_url = $this->base_url."/"; }
| { $this->base_url = $this->base_url."/"; }
|
Zeile 86 | Zeile 86 |
---|
// Get rid of cartridge returns for they are the workings of the devil $message = str_replace("\r", "", $message);
|
// Get rid of cartridge returns for they are the workings of the devil $message = str_replace("\r", "", $message);
|
$message = $this->strip_rtl($message);
| |
// Filter bad words if requested. if($options['filter_badwords'] != "no")
| // Filter bad words if requested. if($options['filter_badwords'] != "no")
|
Zeile 108 | Zeile 106 |
---|
{ $message = preg_replace("#<script(.*)>(.*)</script(.*)>#is", "<script$1>$2</script$3>", $message); }
|
{ $message = preg_replace("#<script(.*)>(.*)</script(.*)>#is", "<script$1>$2</script$3>", $message); }
|
$message = preg_replace("#<base(.*)>#is", "<base$1>", $message); $message = preg_replace("#<meta(.*)>#is", "<meta$1>", $message);
| // Remove these completely $message = preg_replace("#\s*<base[^>]*>\s*#is", "", $message); $message = preg_replace("#\s*<meta[^>]*>\s*#is", "", $message);
$message = str_replace(array('<?php', '<!--', '-->', '?>', "<br />\n", "<br>\n"), array('<?php', '<!--', '-->', '?>', "\n", "\n"), $message);
|
} }
| } }
|
Zeile 118 | Zeile 119 |
---|
{ // First we split up the contents of code and php tags to ensure they're not parsed. preg_match_all("#\[(code|php)\](.*?)\[/\\1\](\r\n?|\n?)#si", $message, $code_matches, PREG_SET_ORDER);
|
{ // First we split up the contents of code and php tags to ensure they're not parsed. preg_match_all("#\[(code|php)\](.*?)\[/\\1\](\r\n?|\n?)#si", $message, $code_matches, PREG_SET_ORDER);
|
$message = preg_replace("#\[(code|php)\](.*?)\[/\\1\](\r\n?|\n?)#si", "{{mybb-code}}\n", $message); }
| $message = preg_replace("#\[(code|php)\](.*?)\[/\\1\](\r\n?|\n?)#si", "<mybb-code>\n", $message); }
|
// Always fix bad Javascript in the message. $message = $this->fix_javascript($message);
|
// Always fix bad Javascript in the message. $message = $this->fix_javascript($message);
|
| // Replace "me" code and slaps if we have a username if($options['me_username']) { $message = preg_replace('#(>|^|\r|\n)/me ([^\r\n<]*)#i', "\\1<span style=\"color: red;\">* {$options['me_username']} \\2</span>", $message); $message = preg_replace('#(>|^|\r|\n)/slap ([^\r\n<]*)#i', "\\1<span style=\"color: red;\">* {$options['me_username']} {$lang->slaps} \\2 {$lang->with_trout}</span>", $message); }
|
|
|
// If we can, parse smiliesa
| // If we can, parse smilies
|
if($options['allow_smilies'] != "no") {
|
if($options['allow_smilies'] != "no") {
|
$message = $this->parse_smilies($message, $options['allowhtml']);
| $message = $this->parse_smilies($message, $options['allow_html']);
|
}
// Replace MyCode if requested.
| }
// Replace MyCode if requested.
|
Zeile 140 | Zeile 148 |
---|
$message = $plugins->run_hooks("parse_message", $message); if($options['allow_mycode'] != "no")
|
$message = $plugins->run_hooks("parse_message", $message); if($options['allow_mycode'] != "no")
|
{
| {
|
// Now that we're done, if we split up any code tags, parse them and glue it all back together if(count($code_matches) > 0) {
| // Now that we're done, if we split up any code tags, parse them and glue it all back together if(count($code_matches) > 0) {
|
Zeile 160 | Zeile 168 |
---|
{ $code = $this->mycode_parse_php($text[2]); }
|
{ $code = $this->mycode_parse_php($text[2]); }
|
$message = preg_replace("#\{\{mybb-code\}\}\n?#", $code, $message, 1);
| $message = preg_replace("#\<mybb-code>\n?#", $code, $message, 1);
|
} } }
| } } }
|
Zeile 168 | Zeile 176 |
---|
if($options['nl2br'] != "no") { $message = nl2br($message);
|
if($options['nl2br'] != "no") { $message = nl2br($message);
|
$message = str_replace("</div><br />", "</div>", $message); $message = preg_replace("#<(/?)p>\s*(<br />?)#", "<$1p>", $message); }
| // Fix up new lines and block level elements $message = preg_replace("#(</?(?:html|head|body|form|div|p|table|thead|tbody|tfoot|tr|td|th|ul|ol|li|div|p)[^>]*>)\s*<br />#i", "$1", $message); $message = preg_replace("#( )+(</?(?:html|head|body|form|div|p|table|thead|tbody|tfoot|tr|td|th|ul|ol|li|div|p)[^>]*>)#i", "$2", $message); }
|
$message = my_wordwrap($message);
|
$message = my_wordwrap($message);
|
$message = str_replace(" ", " ", $message);
| |
$message = $plugins->run_hooks("parse_message_end", $message);
|
$message = $plugins->run_hooks("parse_message_end", $message);
|
return $message; }
| return $message; }
|
/** * Converts HTML in a message to their specific entities whilst allowing unicode characters. *
| /** * Converts HTML in a message to their specific entities whilst allowing unicode characters. *
|
Zeile 202 | Zeile 209 |
---|
*/ function cache_mycode() {
|
*/ function cache_mycode() {
|
global $cache;
| global $cache, $lang;
|
$this->mycode_cache = array();
$standard_mycode['b']['regex'] = "#\[b\](.*?)\[/b\]#si";
| $this->mycode_cache = array();
$standard_mycode['b']['regex'] = "#\[b\](.*?)\[/b\]#si";
|
Zeile 251 | Zeile 258 |
---|
$standard_mycode['size']['replacement'] = "<span style=\"font-size: $1;\">$2</span>";
$standard_mycode['size_int']['regex'] = "#\[size=([0-9\+\-]+?)\](.*?)\[/size\]#si";
|
$standard_mycode['size']['replacement'] = "<span style=\"font-size: $1;\">$2</span>";
$standard_mycode['size_int']['regex'] = "#\[size=([0-9\+\-]+?)\](.*?)\[/size\]#si";
|
$standard_mycode['size_int']['replacement'] = "<font size=\"$1\">$2</font>";
| $standard_mycode['size_int']['replacement'] = "<span style=\"font-size: $1em;\">$2</span>";
|
$standard_mycode['font']['regex'] = "#\[font=([a-z ]+?)\](.+?)\[/font\]#si"; $standard_mycode['font']['replacement'] = "<span style=\"font-family: $1;\">$2</span>";
| $standard_mycode['font']['regex'] = "#\[font=([a-z ]+?)\](.+?)\[/font\]#si"; $standard_mycode['font']['replacement'] = "<span style=\"font-family: $1;\">$2</span>";
|
Zeile 277 | Zeile 284 |
---|
{ $mycode = $standard_mycode; }
|
{ $mycode = $standard_mycode; }
|
|
|
// Assign the MyCode to the cache. foreach($mycode as $code) {
| // Assign the MyCode to the cache. foreach($mycode as $code) {
|
Zeile 306 | Zeile 313 |
---|
// Parse quotes first $message = $this->mycode_parse_quotes($message);
|
// Parse quotes first $message = $this->mycode_parse_quotes($message);
|
$message = $this->mycode_auto_url($message);
| $message = $this->mycode_auto_url($message);
$message = str_replace('$', '$', $message);
|
// Replace the rest $message = preg_replace($this->mycode_cache['find'], $this->mycode_cache['replacement'], $message);
// Special code requiring special attention while(preg_match("#\[list\](.*?)\[/list\]#esi", $message))
|
// Replace the rest $message = preg_replace($this->mycode_cache['find'], $this->mycode_cache['replacement'], $message);
// Special code requiring special attention while(preg_match("#\[list\](.*?)\[/list\]#esi", $message))
|
{
| {
|
$message = preg_replace("#\[list\](.*?)\[/list\](\r\n?|\n?)#esi", "\$this->mycode_parse_list('$1')\n", $message); }
| $message = preg_replace("#\[list\](.*?)\[/list\](\r\n?|\n?)#esi", "\$this->mycode_parse_list('$1')\n", $message); }
|
Zeile 325 | Zeile 334 |
---|
// Convert images when allowed. if($options['allow_imgcode'] != "no")
|
// Convert images when allowed. if($options['allow_imgcode'] != "no")
|
{
| {
|
$message = preg_replace("#\[img\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$2')\n", $message); $message = preg_replace("#\[img=([0-9]{1,3})x([0-9]{1,3})\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$4', array('$1', '$2'));", $message);
|
$message = preg_replace("#\[img\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$2')\n", $message); $message = preg_replace("#\[img=([0-9]{1,3})x([0-9]{1,3})\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$4', array('$1', '$2'));", $message);
|
}
// Replace "me" code and slaps if we have a username if($options['me_username']) { $message = preg_replace('#(>|^|\r|\n)/me ([^\r\n<]*)#i', "\\1<span style=\"color: red;\">* {$options['me_username']} \\2</span>", $message); $message = preg_replace('#(>|^|\r|\n)/slap ([^\r\n<]*)#i', "\\1<span style=\"color: red;\">* {$options['me_username']} {$lang->slaps} \\2 {$lang->with_trout}</span>", $message); }
| $message = preg_replace("#\[img align=([a-z]+)\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$3', array(), '$1');", $message); $message = preg_replace("#\[img=([0-9]{1,3})x([0-9]{1,3}) align=([a-z]+)\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$5', array('$1', '$2'), '$3');", $message); }
|
return $message; }
/** * Generates a cache of smilies
|
return $message; }
/** * Generates a cache of smilies
|
* * @access private */
| * * @access private */
|
function cache_smilies() { global $cache;
| function cache_smilies() { global $cache;
|
Zeile 354 | Zeile 358 |
---|
if(is_array($smilies)) { foreach($smilies as $sid => $smilie)
|
if(is_array($smilies)) { foreach($smilies as $sid => $smilie)
|
{
| {
|
$this->smilies_cache[$smilie['find']] = "<img src=\"{$this->base_url}{$smilie['image']}\" style=\"vertical-align: middle;\" border=\"0\" alt=\"{$smilie['name']}\" title=\"{$smilie['name']}\" />"; } }
| $this->smilies_cache[$smilie['find']] = "<img src=\"{$this->base_url}{$smilie['image']}\" style=\"vertical-align: middle;\" border=\"0\" alt=\"{$smilie['name']}\" title=\"{$smilie['name']}\" />"; } }
|
Zeile 374 | Zeile 378 |
---|
{ $this->cache_smilies(); }
|
{ $this->cache_smilies(); }
|
| $message = ' ' . $message . ' ';
// First we take out any of the tags we don't want parsed between (url= etc) preg_match_all("#\[(url=([^\]]*])|url\].*\[\/url\])#i", $message, $bad_matches, PREG_PATTERN_ORDER); $message = preg_replace("#\[(url=([^\]]*])|url\].*\[\/url\])#si", "<mybb-bad-sm>", $message);
// Impose a hard limit of 500 smilies per message as to not overload the parser $remaining = 500;
|
if(is_array($this->smilies_cache))
|
if(is_array($this->smilies_cache))
|
{ reset($this->smilies_cache);
| {
|
foreach($this->smilies_cache as $find => $replace)
|
foreach($this->smilies_cache as $find => $replace)
|
{ if($allow_html != "yes")
| { if(version_compare(PHP_VERSION, "5.1.0", ">=")) { $message = preg_replace('#([^<])(?<!"|&|"|<|>|&\#[0-9]{1}|&\#[0-9]{2}|&\#[0-9]{3}|&\#[0-9]{4})'.preg_quote($find, "#")."#is", "$1".$replace, $message, $remaining, $replacements); $remaining -= $replacements; if($remaining <= 0) break; // Reached the limit } else
|
{
|
{
|
$find = $this->parse_html($find);
| $message = preg_replace('#([^<])(?<!"|&|"|<|>|&\#[0-9]{1}|&\#[0-9]{2}|&\#[0-9]{3}|&\#[0-9]{4})'.preg_quote($find, "#")."#is", "$1".$replace, $message, $remaining);
|
}
|
}
|
$message = str_replace($find, $replace, $message);
| |
} }
|
} }
|
return $message;
| // If we matched any tags previously, swap them back in if(count($bad_matches[0]) > 0) { foreach($bad_matches[0] as $match) { $message = preg_replace("#<mybb-bad-sm>#", $match, $message, 1); } }
return trim($message);
|
}
/**
| }
/**
|
Zeile 403 | Zeile 430 |
---|
/** * Parses a list of filtered/badwords in the specified message.
|
/** * Parses a list of filtered/badwords in the specified message.
|
* * @param string The message to be parsed.
| * * @param string The message to be parsed.
|
* @param array Array of parser options in yes/no format. * @return string The parsed message. */
| * @param array Array of parser options in yes/no format. * @return string The parsed message. */
|
Zeile 421 | Zeile 448 |
---|
{ if(!$badword['replacement']) $badword['replacement'] = "*****"; $badword['badword'] = preg_quote($badword['badword']);
|
{ if(!$badword['replacement']) $badword['replacement'] = "*****"; $badword['badword'] = preg_quote($badword['badword']);
|
$message = preg_replace("#\b".$badword['badword']."\b#i", $badword['replacement'], $message);
| $message = preg_replace("#(\W|^)".$badword['badword']."(\W|$)#i", "\\1".$badword['replacement']."\\2", $message);
|
} } if($options['strip_tags'] == "yes") { $message = strip_tags($message);
|
} } if($options['strip_tags'] == "yes") { $message = strip_tags($message);
|
} return $message; }
/**
| } return $message; }
/**
|
* Attempts to move any javascript references in the specified message. * * @param string The message to be parsed.
| * Attempts to move any javascript references in the specified message. * * @param string The message to be parsed.
|
Zeile 440 | Zeile 467 |
---|
function fix_javascript($message) { $js_array = array(
|
function fix_javascript($message) { $js_array = array(
|
"#(j)(avascript)#i", "#(a)(lert)#i", "#(o)(nmouseover)#i", "#(o)(nmouseout)#i", "#(o)(nmousedown)#i", "#(o)(nmousemove)#i", "#(o)(nmouseup)#i", "#(o)(nclick)#i", "#(o)(ndblclick)#i", "#(o)(nload)#i", "#(o)(nsubmit)#i", "#(o)(nblur)#i", "#(o)(nchange)#i", "#(o)(nfocus)#i", "#(o)(nselect)#i", "#(o)(nunload)#i", "#(o)(nkeypress)#i" );
| "#(&\#(0*)106;|&\#(0*)74;|j)((&\#(0*)97;|&\#(0*)65;|a)(&\#(0*)118;|&\#(0*)86;|v)(&\#(0*)97;|&\#(0*)65;|a)(\s)?(&\#(0*)115;|&\#(0*)83;|s)(&\#(0*)99;|&\#(0*)67;|c)(&\#(0*)114;|&\#(0*)82;|r)(&\#(0*)105;|&\#(0*)73;|i)(&\#112;|&\#(0*)80;|p)(&\#(0*)116;|&\#(0*)84;|t)(&\#(0*)58;|\:))#i", "#(o)(nmouseover\s?=)#i", "#(o)(nmouseout\s?=)#i", "#(o)(nmousedown\s?=)#i", "#(o)(nmousemove\s?=)#i", "#(o)(nmouseup\s?=)#i", "#(o)(nclick\s?=)#i", "#(o)(ndblclick\s?=)#i", "#(o)(nload\s?=)#i", "#(o)(nsubmit\s?=)#i", "#(o)(nblur\s?=)#i", "#(o)(nchange\s?=)#i", "#(o)(nfocus\s?=)#i", "#(o)(nselect\s?=)#i", "#(o)(nunload\s?=)#i", "#(o)(nkeypress\s?=)#i" );
|
$message = preg_replace($js_array, "$1<strong></strong>$2", $message);
|
$message = preg_replace($js_array, "$1<strong></strong>$2", $message);
|
|
|
return $message; }
| return $message; }
|
Zeile 475 | Zeile 502 |
---|
// Assign pattern and replace values. $pattern = array("#\[quote=(?:"|\"|')?(.*?)[\"']?(?:"|\"|')?\](.*?)\[\/quote\](\r\n?|\n?)#si", "#\[quote\](.*?)\[\/quote\](\r\n?|\n?)#si");
|
// Assign pattern and replace values. $pattern = array("#\[quote=(?:"|\"|')?(.*?)[\"']?(?:"|\"|')?\](.*?)\[\/quote\](\r\n?|\n?)#si", "#\[quote\](.*?)\[\/quote\](\r\n?|\n?)#si");
|
|
|
$replace = array("</p>\n<div class=\"quote_header\">".htmlentities('\\1')." $lang->wrote\n</div><div class=\"quote_body\">$2</div>\n<p>\n", "</p>\n<div class=\"quote_header\">$lang->quote\n</div><div class=\"quote_body\">$1</div>\n<p>\n");
| $replace = array("</p>\n<div class=\"quote_header\">".htmlentities('\\1')." $lang->wrote\n</div><div class=\"quote_body\">$2</div>\n<p>\n", "</p>\n<div class=\"quote_header\">$lang->quote\n</div><div class=\"quote_body\">$1</div>\n<p>\n");
|
Zeile 493 | Zeile 521 |
---|
"</div>" ); $message = preg_replace($find, $replace, $message);
|
"</div>" ); $message = preg_replace($find, $replace, $message);
|
return $message;
}
/**
| return $message;
}
/**
|
* Parses code MyCode. * * @param string The message to be parsed
| * Parses code MyCode. * * @param string The message to be parsed
|
Zeile 506 | Zeile 534 |
---|
function mycode_parse_code($code) { global $lang;
|
function mycode_parse_code($code) { global $lang;
|
$code = trim($code);
| // Clean the string before parsing. $code = preg_replace('#^(\t*)(\n|\r|\0|\x0B| )*#', '\\1', $code); $code = rtrim($code); $original = preg_replace('#^\t*#', '', $code);
if(empty($original)) { return; }
$code = str_replace('$', '$', $code);
|
$code = preg_replace('#\$([0-9])#', '\\\$\\1', $code);
|
$code = preg_replace('#\$([0-9])#', '\\\$\\1', $code);
|
| $code = str_replace('\\', '\', $code); $code = str_replace("\t", ' ', $code); $code = str_replace(" ", ' ', $code);
|
return "</p>\n<div class=\"code_header\">".$lang->code."\n</div><div class=\"code_body\"><div dir=\"ltr\"><code>".$code."</code></div></div>\n<p>\n"; }
| return "</p>\n<div class=\"code_header\">".$lang->code."\n</div><div class=\"code_body\"><div dir=\"ltr\"><code>".$code."</code></div></div>\n<p>\n"; }
|
Zeile 522 | Zeile 564 |
---|
global $lang;
// Clean the string before parsing.
|
global $lang;
// Clean the string before parsing.
|
$str = trim($str); if(!$str)
| $str = preg_replace('#^(\t*)(\n|\r|\0|\x0B| )*#', '\\1', $str); $str = rtrim($str);
$original = preg_replace('#^\t*#', '', $str);
if(empty($original))
|
{ return; }
|
{ return; }
|
| $str = str_replace('&', '&', $str);
|
$str = str_replace('<', '<', $str); $str = str_replace('>', '>', $str);
|
$str = str_replace('<', '<', $str); $str = str_replace('>', '>', $str);
|
$str = str_replace('&', '&', $str); $original = $str;
|
|
// See if open and close tags are provided.
|
// See if open and close tags are provided.
|
$added_open_close = false;
| $added_open_tag = false;
|
if(!preg_match("#^\s*<\?#si", $str)) {
|
if(!preg_match("#^\s*<\?#si", $str)) {
|
$added_open_close = true; $str = "<?php \n".$str." \n?>";
| $added_open_tag = true; $str = "<?php \n".$str; }
$added_end_tag = false; if(!preg_match("#\?>\s*$#si", $str)) { $added_end_tag = true; $str = $str." \n?>";
|
}
|
}
|
|
|
// If the PHP version < 4.2, catch highlight_string() output. if(version_compare(PHP_VERSION, "4.2.0", "<"))
|
// If the PHP version < 4.2, catch highlight_string() output. if(version_compare(PHP_VERSION, "4.2.0", "<"))
|
{
| {
|
ob_start(); @highlight_string($str); $code = ob_get_contents();
| ob_start(); @highlight_string($str); $code = ob_get_contents();
|
Zeile 549 | Zeile 604 |
---|
else { $code = @highlight_string($str, true);
|
else { $code = @highlight_string($str, true);
|
}
| }
|
// If < PHP 5, make XHTML compatible. if(version_compare(PHP_VERSION, "5", "<")) {
| // If < PHP 5, make XHTML compatible. if(version_compare(PHP_VERSION, "5", "<")) {
|
Zeile 557 | Zeile 613 |
---|
"<font", "color=\"", "</font>"
|
"<font", "color=\"", "</font>"
|
);
| );
|
$replace = array( "<span", "style=\"color: ",
| $replace = array( "<span", "style=\"color: ",
|
Zeile 572 | Zeile 627 |
---|
$code = preg_replace("#</span>\s*</code>#", "</code>", $code); $code = preg_replace("#</span>(\r\n?|\n?)</code>#", "</span></code>", $code); $code = str_replace("\\", '\', $code);
|
$code = preg_replace("#</span>\s*</code>#", "</code>", $code); $code = preg_replace("#</span>(\r\n?|\n?)</code>#", "</span></code>", $code); $code = str_replace("\\", '\', $code);
|
| $code = str_replace('$', '$', $code);
|
$code = preg_replace("#&\#([0-9]+);#si", "&#$1;", $code);
|
$code = preg_replace("#&\#([0-9]+);#si", "&#$1;", $code);
|
| if($added_open_tag) { $code = preg_replace("#<code><span style=\"color: \#([A-Z0-9]{6})\"><\?php( | )(<br />?)#", "<code><span style=\"color: #$1\">", $code); }
|
|
|
if($added_open_close == true)
| if($added_end_tag)
|
{
|
{
|
$code = preg_replace("#<code><span style=\"color: \#([A-Z0-9]{6})\"><\?php( | )(<br />?)#", "<code><span style=\"color: #$1\">", $code);
| |
$code = str_replace("?></span></code>", "</span></code>", $code);
|
$code = str_replace("?></span></code>", "</span></code>", $code);
|
| // Wait a minute. It fails highlighting? Stupid highlighter. $code = str_replace("?></code>", "</code>", $code);
|
}
$code = preg_replace("#<span style=\"color: \#([A-Z0-9]{6})\"></span>#", "", $code);
| }
$code = preg_replace("#<span style=\"color: \#([A-Z0-9]{6})\"></span>#", "", $code);
|
Zeile 622 | Zeile 683 |
---|
$fullurl = stripslashes($fullurl); if($name == $url && $this->options['shorten_urls'] != "no") {
|
$fullurl = stripslashes($fullurl); if($name == $url && $this->options['shorten_urls'] != "no") {
|
if(strlen($url) > 55)
| if(my_strlen($url) > 55)
|
{ $name = my_substr($url, 0, 40)."...".my_substr($url, -10); }
| { $name = my_substr($url, 0, 40)."...".my_substr($url, -10); }
|
Zeile 639 | Zeile 700 |
---|
* @param string The URL to the image * @param array Optional array of dimensions */
|
* @param string The URL to the image * @param array Optional array of dimensions */
|
function mycode_parse_img($url, $dimensions=array())
| function mycode_parse_img($url, $dimensions=array(), $align='')
|
{ $url = trim($url); $url = str_replace("\n", "", $url); $url = str_replace("\r", "", $url);
|
{ $url = trim($url); $url = str_replace("\n", "", $url); $url = str_replace("\r", "", $url);
|
if($dimensions[0] > 0 && $dimensions[1] > 0)
| if($align == "right")
|
{
|
{
|
return "<img src=\"{$url}\" width=\"{$dimensions[0]}\" height=\"{$dimensions[1]}\" border=\"0\" alt=\"\" />";
| $css_align = " style=\"float: right;\""; } else if($align == "left") { $css_align = " style=\"float: left;\""; } if($dimensions[0] > 0 && $dimensions[1] > 0) { return "<img src=\"{$url}\" width=\"{$dimensions[0]}\" height=\"{$dimensions[1]}\" border=\"0\" alt=\"\"{$css_align} />";
|
} else {
|
} else {
|
return "<img src=\"{$url}\" border=\"0\" alt=\"\" />";
| return "<img src=\"{$url}\" border=\"0\" alt=\"\"{$css_align} />";
|
} }
| } }
|
Zeile 660 | Zeile 729 |
---|
* @param string The email address to link to. * @param string The name for the link. * @return string The built-up email link.
|
* @param string The email address to link to. * @param string The name for the link. * @return string The built-up email link.
|
*/
| */
|
function mycode_parse_email($email, $name="") { if(!$name)
|
function mycode_parse_email($email, $name="") { if(!$name)
|
{
| {
|
$name = $email; } if(preg_match("/^([a-zA-Z0-9-_\+\.]+?)@[a-zA-Z0-9-]+\.[a-zA-Z0-9\.-]+$/si", $email))
|
$name = $email; } if(preg_match("/^([a-zA-Z0-9-_\+\.]+?)@[a-zA-Z0-9-]+\.[a-zA-Z0-9\.-]+$/si", $email))
|
{
| {
|
return "<a href=\"mailto:$email\">".$name."</a>";
|
return "<a href=\"mailto:$email\">".$name."</a>";
|
}
| }
|
else { return $email;
|
else { return $email;
|
} }
/**
| } }
/**
|
* Parses URLs automatically. * * @param string The message to be parsed
| * Parses URLs automatically. * * @param string The message to be parsed
|
Zeile 701 | Zeile 770 |
---|
function mycode_parse_list($message, $type="") { $message = str_replace('\"', '"', $message);
|
function mycode_parse_list($message, $type="") { $message = str_replace('\"', '"', $message);
|
$message = preg_replace("#\[\*\]\s?#", "</li><li>", $message);
| $message = preg_replace("#\s*\[\*\]\s*#", "</li>\n<li>", $message);
|
$message .= "</li>";
if($type)
|
$message .= "</li>";
if($type)
|
{ $list = "</p>\n<ol type=\"$type\">$message</ol>\n<p>"; }
| { $list = "\n<ol type=\"$type\">$message</ol>\n"; }
|
else {
|
else {
|
$list = "</p>\n<ul>$message</ul>\n</p>";
| $list = "<ul>$message</ul>\n";
|
} $list = preg_replace("#<(ol type=\"$type\"|ul)>\s*</li>#", "<$1>", $list); return $list; }
|
} $list = preg_replace("#<(ol type=\"$type\"|ul)>\s*</li>#", "<$1>", $list); return $list; }
|
/**
| /**
|
* Strips smilies from a string * * @param string The message for smilies to be stripped from
| * Strips smilies from a string * * @param string The message for smilies to be stripped from
|
Zeile 725 | Zeile 794 |
---|
function strip_smilies($message) { if($this->smilies_cache == 0)
|
function strip_smilies($message) { if($this->smilies_cache == 0)
|
{
| {
|
$this->cache_smilies();
|
$this->cache_smilies();
|
}
| }
|
if(is_array($this->smilies_cache)) { $message = str_replace($this->smilies_cache, array_keys($this->smilies_cache), $message); }
|
if(is_array($this->smilies_cache)) { $message = str_replace($this->smilies_cache, array_keys($this->smilies_cache), $message); }
|
return $message;
| return $message;
|
}
|
}
|
/** * Strip RTL Unicude * */ function strip_rtl($message) { //$message = htmlentities($message); //$message = preg_replace('/[^\x09\x0A\x0D\x20-\x7F]/e', '"&#".ord($0).";"', $message); //$message = str_replace('‮', '', $message); //$message = str_replace('‮', '', $message); //$message = str_replace('‮', '', $message); //$message = html_entity_decode($message); return $message; }
| |
/** * Strips MyCode.
| /** * Strips MyCode.
|