Merge branch 'master' of https://github.com/savetheinternet/Tinyboard
This commit is contained in:
commit
ee23ec1e24
@ -298,6 +298,10 @@ function sprintf3($str, $vars, $delim = '%') {
|
|||||||
array_values($replaces), $str);
|
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) {
|
function setupBoard($array) {
|
||||||
global $board, $config;
|
global $board, $config;
|
||||||
|
|
||||||
@ -1481,6 +1485,7 @@ function markup(&$body, $track_cites = false) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$skip_chars = 0;
|
$skip_chars = 0;
|
||||||
|
$body_tmp = $body;
|
||||||
|
|
||||||
foreach ($cites as $matches) {
|
foreach ($cites as $matches) {
|
||||||
$cite = $matches[2][0];
|
$cite = $matches[2][0];
|
||||||
@ -1488,12 +1493,18 @@ function markup(&$body, $track_cites = false) {
|
|||||||
$query->bindValue(':id', $cite);
|
$query->bindValue(':id', $cite);
|
||||||
$query->execute() or error(db_error($query));
|
$query->execute() or error(db_error($query));
|
||||||
|
|
||||||
|
// preg_match_all is not multibyte-safe
|
||||||
|
foreach ($matches as &$match) {
|
||||||
|
$match[1] = mb_strlen(substr($body_tmp, 0, $match[1]));
|
||||||
|
}
|
||||||
|
|
||||||
if ($post = $query->fetch()) {
|
if ($post = $query->fetch()) {
|
||||||
$replacement = '<a onclick="highlightReply(\''.$cite.'\');" href="' .
|
$replacement = '<a onclick="highlightReply(\''.$cite.'\');" href="' .
|
||||||
$config['root'] . $board['dir'] . $config['dir']['res'] . ($post['thread']?$post['thread']:$post['id']) . '.html#' . $cite . '">' .
|
$config['root'] . $board['dir'] . $config['dir']['res'] . ($post['thread']?$post['thread']:$post['id']) . '.html#' . $cite . '">' .
|
||||||
'>>' . $cite .
|
'>>' . $cite .
|
||||||
'</a>';
|
'</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]);
|
$skip_chars += mb_strlen($matches[1][0] . $replacement . $matches[3][0]) - mb_strlen($matches[0][0]);
|
||||||
|
|
||||||
if ($track_cites && $config['track_cites'])
|
if ($track_cites && $config['track_cites'])
|
||||||
@ -1509,11 +1520,17 @@ function markup(&$body, $track_cites = false) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$skip_chars = 0;
|
$skip_chars = 0;
|
||||||
|
$body_tmp = $body;
|
||||||
|
|
||||||
foreach ($cites as $matches) {
|
foreach ($cites as $matches) {
|
||||||
$_board = $matches[2][0];
|
$_board = $matches[2][0];
|
||||||
$cite = @$matches[3][0];
|
$cite = @$matches[3][0];
|
||||||
|
|
||||||
|
// preg_match_all 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
|
// Temporarily store board information because it will be overwritten
|
||||||
$tmp_board = $board['uri'];
|
$tmp_board = $board['uri'];
|
||||||
|
|
||||||
@ -1529,7 +1546,8 @@ function markup(&$body, $track_cites = false) {
|
|||||||
$config['root'] . $board['dir'] . $config['dir']['res'] . ($post['thread']?$post['thread']:$post['id']) . '.html#' . $cite . '">' .
|
$config['root'] . $board['dir'] . $config['dir']['res'] . ($post['thread']?$post['thread']:$post['id']) . '.html#' . $cite . '">' .
|
||||||
'>>>/' . $_board . '/' . $cite .
|
'>>>/' . $_board . '/' . $cite .
|
||||||
'</a>';
|
'</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]);
|
$skip_chars += mb_strlen($matches[1][0] . $replacement . $matches[4][0]) - mb_strlen($matches[0][0]);
|
||||||
|
|
||||||
if ($track_cites && $config['track_cites'])
|
if ($track_cites && $config['track_cites'])
|
||||||
@ -1540,7 +1558,7 @@ function markup(&$body, $track_cites = false) {
|
|||||||
$config['root'] . $board['dir'] . $config['file_index'] . '">' .
|
$config['root'] . $board['dir'] . $config['file_index'] . '">' .
|
||||||
'>>>/' . $_board . '/' .
|
'>>>/' . $_board . '/' .
|
||||||
'</a>';
|
'</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]);
|
$skip_chars += mb_strlen($matches[1][0] . $replacement . $matches[4][0]) - mb_strlen($matches[0][0]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<form name="post" onsubmit="return dopost(this);" enctype="multipart/form-data" action="{{ config.post_url }}" method="post">
|
<form name="post" onsubmit="return dopost(this);" enctype="multipart/form-data" action="{{ config.post_url }}" method="post" autocomplete="off">
|
||||||
{{ antibot.html() }}
|
{{ antibot.html() }}
|
||||||
{% if id %}<input type="hidden" name="thread" value="{{ id }}">{% endif %}
|
{% if id %}<input type="hidden" name="thread" value="{{ id }}">{% endif %}
|
||||||
{{ antibot.html() }}
|
{{ antibot.html() }}
|
||||||
|
Loading…
Reference in New Issue
Block a user