X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=killpopup.c;h=e0219002a179f7b479aa4c3ec95b0a5ec07908df;hp=4b1ceb0519c2de2580706bad8b1531d5957c9a12;hb=7baf26f8fbebe8984069fe009aea1fde6ded0c2c;hpb=605576ce35e16c57567f79dd9086bb9ae001753b diff --git a/killpopup.c b/killpopup.c index 4b1ceb05..e0219002 100644 --- a/killpopup.c +++ b/killpopup.c @@ -1,12 +1,12 @@ -const char killpopup_rcs[] = "$Id: killpopup.c,v 1.12 2001/10/25 03:40:48 david__schmidt Exp $"; +const char killpopup_rcs[] = "$Id: killpopup.c,v 1.16 2002/03/26 22:29:55 swa Exp $"; /********************************************************************* * - * File : $Source: /cvsroot/ijbswa/current/killpopup.c,v $ + * File : $Source: /cvsroot/ijbswa/current/Attic/killpopup.c,v $ * * Purpose : Handles the filtering of popups. * * Copyright : Written by and Copyright (C) 2001 the SourceForge - * IJBSWA team. http://ijbswa.sourceforge.net + * Privoxy team. http://www.privoxy.org/ * * Based on the Internet Junkbuster originally written * by and Copyright (C) 1997 Anonymous Coders and @@ -32,6 +32,19 @@ const char killpopup_rcs[] = "$Id: killpopup.c,v 1.12 2001/10/25 03:40:48 david_ * * Revisions : * $Log: killpopup.c,v $ + * Revision 1.16 2002/03/26 22:29:55 swa + * we have a new homepage! + * + * Revision 1.15 2002/03/24 13:25:43 swa + * name change related issues + * + * Revision 1.14 2002/03/07 03:46:53 oes + * Fixed compiler warnings etc + * + * Revision 1.13 2001/11/13 00:16:40 jongfoster + * Replacing references to malloc.h with the standard stdlib.h + * (See ANSI or K&R 2nd Ed) + * * Revision 1.12 2001/10/25 03:40:48 david__schmidt * Change in porting tactics: OS/2's EMX porting layer doesn't allow multiple * threads to call select() simultaneously. So, it's time to do a real, live, @@ -133,59 +146,60 @@ const char killpopup_h_rcs[] = KILLPOPUP_H_VERSION; *********************************************************************/ void filter_popups(char *buff, struct client_state *csp) { - char *popup = NULL; - char *close = NULL; + char *start_p = NULL; + char *close_p = NULL; char *p = NULL; - while ((popup = strstr( buff, "window.open(" )) != NULL) + /* + * replace the window.open( with a harmless JavaScript replacement + * (notice the two single quotes) + */ + while ((start_p = strstr(buff, "window.open(")) != NULL) { - if ( popup ) + if (start_p) { - /* - * replace the window.open( with a harmless JavaScript replacement (notice the two single quotes) - * Guy's idea (thanks) - */ - strncpy(popup, "1;''.concat(", 12); + strncpy(start_p, "1;''.concat(", 12); log_error(LOG_LEVEL_POPUPS, "Blocked popup window open"); csp->flags |= CSP_FLAG_MODIFIED; } } - while ((popup = strstr( buff, ".resizeTo(" )) != NULL) + /* + * replace the .resizeTo( with a harmless JavaScript replacement + */ + while ((start_p = strstr(buff, ".resizeTo(")) != NULL) { - if ( popup ) + if (start_p) { - /* - * replace the .resizeTo( with a harmless JavaScript replacement - * Guy's idea (thanks) - */ - strncpy(popup, ".scrollTo(", 10); + strncpy(start_p, ".scrollTo(", 10); log_error(LOG_LEVEL_POPUPS, "Blocked popup window resize"); csp->flags |= CSP_FLAG_MODIFIED; } } - /* Filter onUnload and onExit */ - popup=strstr( buff, "'); - if (close) + close_p = strchr(start_p, '>'); + if (close_p) { - /* we are now between FIXME: No, we're anywhere! --oes */ - p=strstr(popup, "onUnload"); + /* we are now between */ + p = strstr(start_p, "onUnload"); if (p) { - strncpy(p,"_nU_",4); + strncpy(p, "_nU_", 4); csp->flags |= CSP_FLAG_MODIFIED; } - p=strstr(popup, "onExit"); + p = strstr(start_p, "onExit"); if (p) { - strncpy(p,"_nE_",4); + strncpy(p, "_nE_", 4); csp->flags |= CSP_FLAG_MODIFIED; } }