aboutsummaryrefslogtreecommitdiffstats
path: root/x11/kdelibs4
diff options
context:
space:
mode:
authorlofi <lofi@FreeBSD.org>2007-03-06 21:37:12 +0800
committerlofi <lofi@FreeBSD.org>2007-03-06 21:37:12 +0800
commitcec647a409fd0beefc6025bfaead92cbdd5d7f9b (patch)
tree1de0f4b9c99304d1526b7bb8a5a6d4ac5afb1d26 /x11/kdelibs4
parent4c0780c976d533b110e0f465ef303a26a039b83b (diff)
downloadfreebsd-ports-gnome-cec647a409fd0beefc6025bfaead92cbdd5d7f9b.tar.gz
freebsd-ports-gnome-cec647a409fd0beefc6025bfaead92cbdd5d7f9b.tar.zst
freebsd-ports-gnome-cec647a409fd0beefc6025bfaead92cbdd5d7f9b.zip
Fix for .contentWindow queries crashing on invalid windows.
Security: http://bindshell.net/advisories/konq355 Obtained from: KDE SVN
Diffstat (limited to 'x11/kdelibs4')
-rw-r--r--x11/kdelibs4/Makefile2
-rw-r--r--x11/kdelibs4/files/patch-khtml_ecma-kjs_html.cpp36
2 files changed, 37 insertions, 1 deletions
diff --git a/x11/kdelibs4/Makefile b/x11/kdelibs4/Makefile
index 67521ce0ef6f..0ed68a7d7aee 100644
--- a/x11/kdelibs4/Makefile
+++ b/x11/kdelibs4/Makefile
@@ -8,7 +8,7 @@
PORTNAME= kdelibs
PORTVERSION= ${KDE_VERSION}
-PORTREVISION= 2
+PORTREVISION= 3
CATEGORIES= x11 kde ipv6
MASTER_SITES= ${MASTER_SITE_KDE}
MASTER_SITE_SUBDIR= stable/${PORTVERSION:S/.0//}/src
diff --git a/x11/kdelibs4/files/patch-khtml_ecma-kjs_html.cpp b/x11/kdelibs4/files/patch-khtml_ecma-kjs_html.cpp
new file mode 100644
index 000000000000..57e66a5b95f8
--- /dev/null
+++ b/x11/kdelibs4/files/patch-khtml_ecma-kjs_html.cpp
@@ -0,0 +1,36 @@
+--- khtml/ecma/kjs_html.cpp 2007/02/26 16:39:44 637497
++++ khtml/ecma/kjs_html.cpp 2007/03/05 13:15:20 639609
+@@ -1866,10 +1866,12 @@
+ getDOMNode(exec, frameElement.contentDocument()) : Undefined();
+ case FrameContentWindow: {
+ KHTMLPart* part = static_cast<DOM::HTMLFrameElementImpl*>(frameElement.handle())->contentPart();
+- if (part)
+- return Value(Window::retrieveWindow(part));
+- else
+- return Undefined();
++ if (part) {
++ Window *w = Window::retrieveWindow(part);
++ if (w)
++ return Value(w);
++ }
++ return Undefined();
+ }
+ case FrameFrameBorder: return String(frameElement.frameBorder());
+ case FrameLongDesc: return String(frameElement.longDesc());
+@@ -1899,10 +1901,12 @@
+ getDOMNode(exec, iFrame.contentDocument()) : Undefined();
+ case IFrameContentWindow: {
+ KHTMLPart* part = static_cast<DOM::HTMLIFrameElementImpl*>(iFrame.handle())->contentPart();
+- if (part)
+- return Value(Window::retrieveWindow(part));
+- else
+- return Undefined();
++ if (part) {
++ Window *w = Window::retrieveWindow(part);
++ if (w)
++ return Value(w);
++ }
++ return Undefined();
+ }
+ case IFrameFrameBorder: return String(iFrame.frameBorder());
+ case IFrameHeight: return String(iFrame.height());