[Xfce4-commits] <midori:master> Handle https:// URIs in Adblock properly

Christian Dywan noreply at xfce.org
Tue Apr 6 02:42:01 CEST 2010


Updating branch refs/heads/master
         to 95358acc820c532722b779b9708b7b2511369fd2 (commit)
       from 51b1f8740070104f531cb3725de9507010fd1d29 (commit)

commit 95358acc820c532722b779b9708b7b2511369fd2
Author: Christian Dywan <christian at twotoasts.de>
Date:   Mon Apr 5 23:20:45 2010 +0200

    Handle https:// URIs in Adblock properly
    
    We mark URIs as 'disabled' by replacing the : with a -. This
    fails if there is an https:// URI and we want to restore it.
    
    For clarity, the macros ADBLOCK_FILTER_SET and
    ADBLOCK_FILTER_IS_SET are introduced to handle the details.

 extensions/adblock.c |   12 ++++++++----
 1 files changed, 8 insertions(+), 4 deletions(-)

diff --git a/extensions/adblock.c b/extensions/adblock.c
index 6112a94..0ec1c22 100644
--- a/extensions/adblock.c
+++ b/extensions/adblock.c
@@ -28,6 +28,10 @@
 #define ADBLOCK_FILTER_VALID(__filter) \
     (__filter && (g_str_has_prefix (__filter, "http") \
                || g_str_has_prefix (__filter, "file")))
+#define ADBLOCK_FILTER_SET(__filter,__active) \
+    filter[4] = __active ? (__filter[5] == ':' ? 's' : ':') : '-'
+#define ADBLOCK_FILTER_IS_SET(__filter) \
+    filter[4] != '-'
 
 static GHashTable* pattern;
 static GHashTable* keys;
@@ -192,7 +196,7 @@ adblock_preferences_render_tick_cb (GtkTreeViewColumn* column,
 
     g_object_set (renderer,
         "activatable", ADBLOCK_FILTER_VALID (filter),
-        "active", ADBLOCK_FILTER_VALID (filter) && filter[4] != '-',
+        "active", ADBLOCK_FILTER_VALID (filter) && ADBLOCK_FILTER_IS_SET (filter),
         NULL);
 
     g_free (filter);
@@ -225,7 +229,7 @@ adblock_preferences_renderer_toggle_toggled_cb (GtkCellRendererToggle* renderer,
 
         if (ADBLOCK_FILTER_VALID (filter))
         {
-            filter[4] = ':';
+            ADBLOCK_FILTER_SET (filter, TRUE);
             if (gtk_cell_renderer_toggle_get_active (renderer))
             {
                 if (!strncmp (filter, "http", 4))
@@ -234,7 +238,7 @@ adblock_preferences_renderer_toggle_toggled_cb (GtkCellRendererToggle* renderer,
                     g_unlink (filename);
                     g_free (filename);
                 }
-                filter[4] = '-';
+                ADBLOCK_FILTER_SET (filter, FALSE);
             }
 
             gtk_list_store_set (GTK_LIST_STORE (model), &iter, 0, filter, -1);
@@ -256,7 +260,7 @@ adblock_preferences_render_text_cb (GtkTreeViewColumn* column,
     gtk_tree_model_get (model, iter, 0, &filter, -1);
 
     if (ADBLOCK_FILTER_VALID (filter))
-        filter[4] = ':';
+        ADBLOCK_FILTER_SET (filter, TRUE);
 
     g_object_set (renderer,
         "text", filter,



More information about the Xfce4-commits mailing list