[Xfce4-commits] <midori:master> Optimize private element hider algorithm

Christian Dywan noreply at xfce.org
Wed Dec 7 20:40:04 CET 2011


Updating branch refs/heads/master
         to 98f2e3b572dead2a22a63a1227ec13e88d611e18 (commit)
       from 42387e9b8ba64a1dff6cff8c4d741a206ebbfe81 (commit)

commit 98f2e3b572dead2a22a63a1227ec13e88d611e18
Author: Alexander Butenko <a.butenka at gmail.com>
Date:   Mon Dec 5 20:24:08 2011 -0400

    Optimize private element hider algorithm

 extensions/adblock.c |   30 +++++++++++++++++++++++-------
 1 files changed, 23 insertions(+), 7 deletions(-)

diff --git a/extensions/adblock.c b/extensions/adblock.c
index 3248f66..1b8e75e 100644
--- a/extensions/adblock.c
+++ b/extensions/adblock.c
@@ -61,14 +61,21 @@ adblock_build_js (const gchar* private)
         "function () {"
         "   if (document.getElementById('madblock'))"
         "       return;"
-        "   var URL = location.href;"
+            // Get just domain name from URL
+        "   var URL = location.href.match(/:\\/\\/(.[^/]+)/)[1];"
         "   var sites = new Array(); %s;"
         "   var public = '.madblockplaceholder ';"
-        "   for (var i in sites) {"
-        "       if (URL.indexOf(i) != -1 && sites[i] ){"
-        "           public += ', .'+sites[i];"
-        "           break;"
-        "   }}"
+            // Split domain into subdomain parts
+        "   var subdomains = URL.split ('.');"
+        "   var hostname = subdomains [subdomains.length - 1];"
+        "   var i = subdomains.length - 2;"
+            // Check if any of subdomains do have blocking rules
+        "   while (i >= 0) {"
+        "       hostname = subdomains [i] + '.' + hostname;"
+        "       if (sites [hostname])"
+        "           public += ', ' + sites [hostname];"
+        "       i--;"
+        "   }"
         "   public += ' {display: none !important}';"
         "   var mystyle = document.createElement('style');"
         "   mystyle.setAttribute('type', 'text/css');"
@@ -1218,8 +1225,17 @@ adblock_frame_add_private (const gchar* line,
         domains = g_strsplit (data[0], ",", -1);
         for (i = 0; domains[i]; i++)
         {
+            gchar* domain;
+
+            domain = domains[i];
+            /* Ignore Firefox-specific option */
+            if (!g_strcmp0 (domain, "~pregecko2"))
+                continue;
+            /* strip ~ from domain */
+            if (domain[0] == '~')
+                domain++;
             g_string_append_printf (blockcssprivate, ";sites['%s']+=',%s'",
-                g_strstrip (domains[i]), data[1]);
+                g_strstrip (domain), data[1]);
         }
         g_strfreev (domains);
     }


More information about the Xfce4-commits mailing list