diff --git a/inc/display.php b/inc/display.php
index 6fa97f4f..81f8c53d 100644
--- a/inc/display.php
+++ b/inc/display.php
@@ -218,11 +218,50 @@ function truncate($body, $url, $max_lines = false, $max_chars = false) {
return $body;
}
-function bidi_cleanup($str) {
- // Removes all embedded RTL and LTR unicode formatting blocks in a string so that
+function bidi_cleanup($data) {
+ // Closes all embedded RTL and LTR unicode formatting blocks in a string so that
// it can be used inside another without controlling its direction.
- return "$str";
+ $explicits = '\xE2\x80\xAA|\xE2\x80\xAB|\xE2\x80\xAD|\xE2\x80\xAE';
+ $pdf = '\xE2\x80\xAC';
+
+ preg_match_all("!$explicits!", $data, $m1, PREG_OFFSET_CAPTURE | PREG_SET_ORDER);
+ preg_match_all("!$pdf!", $data, $m2, PREG_OFFSET_CAPTURE | PREG_SET_ORDER);
+
+ if (count($m1) || count($m2)){
+
+ $p = array();
+ foreach ($m1 as $m){ $p[$m[0][1]] = 'push'; }
+ foreach ($m2 as $m){ $p[$m[0][1]] = 'pop'; }
+ ksort($p);
+
+ $offset = 0;
+ $stack = 0;
+ foreach ($p as $pos => $type){
+
+ if ($type == 'push'){
+ $stack++;
+ }else{
+ if ($stack){
+ $stack--;
+ }else{
+ # we have a pop without a push - remove it
+ $data = substr($data, 0, $pos-$offset)
+ .substr($data, $pos+3-$offset);
+ $offset += 3;
+ }
+ }
+ }
+
+ # now add some pops if your stack is bigger than 0
+ for ($i=0; $i<$stack; $i++){
+ $data .= "\xE2\x80\xAC";
+ }
+
+ return $data;
+ }
+
+ return $data;
}
function secure_link_confirm($text, $title, $confirm_message, $href) {
diff --git a/stylesheets/style.css b/stylesheets/style.css
index e62891e2..c1725e35 100644
--- a/stylesheets/style.css
+++ b/stylesheets/style.css
@@ -37,6 +37,10 @@ p.intro a.email:hover span.name {
p.intro label {
display: inline;
}
+p.intro time, p.intro a.ip-link, p.intro a.capcode {
+ direction: ltr;
+ unicode-bidi: embed;
+}
h2 {
color: #AF0A0F;
font-size: 11pt;
@@ -406,5 +410,4 @@ table.mod.config-editor input[type="text"] {
p.intro.thread-hidden {
margin: 0px;
padding: 0px;
-}
-
+}
\ No newline at end of file
diff --git a/templates/post_reply.html b/templates/post_reply.html
index a1feb005..c5d24247 100644
--- a/templates/post_reply.html
+++ b/templates/post_reply.html
@@ -26,7 +26,7 @@
{{ capcode.cap }}
{% endif %}
{% if post.mod and post.mod|hasPermission(config.mod.show_ip, board.uri) %}
- [{{ post.ip }}]
+ [{{ post.ip }}]
{% endif %}
{% if config.display_flags and post.modifiers.flag %}
{{ post.ip }}]
+ [{{ post.ip }}]
{% endif %}
{% if config.display_flags and post.modifiers.flag %}