|
|
@ -297,6 +297,10 @@ function sprintf3($str, $vars, $delim = '%') { |
|
|
|
array_values($replaces), $str); |
|
|
|
} |
|
|
|
|
|
|
|
function mb_substr_replace($string, $replacement, $start, $length) { |
|
|
|
return mb_substr($string, 0, $start) . $replacement . mb_substr($string, $start + $length); |
|
|
|
} |
|
|
|
|
|
|
|
function setupBoard($array) { |
|
|
|
global $board, $config; |
|
|
|
|
|
|
@ -1451,6 +1455,7 @@ function markup(&$body, $track_cites = false) { |
|
|
|
} |
|
|
|
|
|
|
|
$skip_chars = 0; |
|
|
|
$body_tmp = $body; |
|
|
|
|
|
|
|
foreach ($cites as $matches) { |
|
|
|
$cite = $matches[2][0]; |
|
|
@ -1458,12 +1463,18 @@ function markup(&$body, $track_cites = false) { |
|
|
|
$query->bindValue(':id', $cite); |
|
|
|
$query->execute() or error(db_error($query)); |
|
|
|
|
|
|
|
// preg_replace is not multibyte-safe |
|
|
|
foreach ($matches as &$match) { |
|
|
|
$match[1] = mb_strlen(substr($body_tmp, 0, $match[1])); |
|
|
|
} |
|
|
|
|
|
|
|
if ($post = $query->fetch()) { |
|
|
|
$replacement = '<a onclick="highlightReply(\''.$cite.'\');" href="' . |
|
|
|
$config['root'] . $board['dir'] . $config['dir']['res'] . ($post['thread']?$post['thread']:$post['id']) . '.html#' . $cite . '">' . |
|
|
|
'>>' . $cite . |
|
|
|
'</a>'; |
|
|
|
$body = substr_replace($body, $matches[1][0] . $replacement . $matches[3][0], $matches[0][1] + $skip_chars, mb_strlen($matches[0][0])); |
|
|
|
|
|
|
|
$body = mb_substr_replace($body, $matches[1][0] . $replacement . $matches[3][0], $matches[0][1] + $skip_chars, mb_strlen($matches[0][0])); |
|
|
|
$skip_chars += mb_strlen($matches[1][0] . $replacement . $matches[3][0]) - mb_strlen($matches[0][0]); |
|
|
|
|
|
|
|
if ($track_cites && $config['track_cites']) |
|
|
@ -1479,11 +1490,17 @@ function markup(&$body, $track_cites = false) { |
|
|
|
} |
|
|
|
|
|
|
|
$skip_chars = 0; |
|
|
|
$body_tmp = $body; |
|
|
|
|
|
|
|
foreach ($cites as $matches) { |
|
|
|
$_board = $matches[2][0]; |
|
|
|
$cite = @$matches[3][0]; |
|
|
|
|
|
|
|
// preg_replace is not multibyte-safe |
|
|
|
foreach ($matches as &$match) { |
|
|
|
$match[1] = mb_strlen(substr($body_tmp, 0, $match[1])); |
|
|
|
} |
|
|
|
|
|
|
|
// Temporarily store board information because it will be overwritten |
|
|
|
$tmp_board = $board['uri']; |
|
|
|
|
|
|
@ -1499,7 +1516,8 @@ function markup(&$body, $track_cites = false) { |
|
|
|
$config['root'] . $board['dir'] . $config['dir']['res'] . ($post['thread']?$post['thread']:$post['id']) . '.html#' . $cite . '">' . |
|
|
|
'>>>/' . $_board . '/' . $cite . |
|
|
|
'</a>'; |
|
|
|
$body = substr_replace($body, $matches[1][0] . $replacement . $matches[4][0], $matches[0][1] + $skip_chars, mb_strlen($matches[0][0])); |
|
|
|
|
|
|
|
$body = mb_substr_replace($body, $matches[1][0] . $replacement . $matches[4][0], $matches[0][1] + $skip_chars, mb_strlen($matches[0][0])); |
|
|
|
$skip_chars += mb_strlen($matches[1][0] . $replacement . $matches[4][0]) - mb_strlen($matches[0][0]); |
|
|
|
|
|
|
|
if ($track_cites && $config['track_cites']) |
|
|
@ -1510,7 +1528,7 @@ function markup(&$body, $track_cites = false) { |
|
|
|
$config['root'] . $board['dir'] . $config['file_index'] . '">' . |
|
|
|
'>>>/' . $_board . '/' . |
|
|
|
'</a>'; |
|
|
|
$body = substr_replace($body, $matches[1][0] . $replacement . $matches[4][0], $matches[0][1] + $skip_chars, mb_strlen($matches[0][0])); |
|
|
|
$body = mb_substr_replace($body, $matches[1][0] . $replacement . $matches[4][0], $matches[0][1] + $skip_chars, mb_strlen($matches[0][0])); |
|
|
|
$skip_chars += mb_strlen($matches[1][0] . $replacement . $matches[4][0]) - mb_strlen($matches[0][0]); |
|
|
|
} |
|
|
|
} |
|
|
|