diff options
author | lofi <lofi@FreeBSD.org> | 2007-03-06 21:37:12 +0800 |
---|---|---|
committer | lofi <lofi@FreeBSD.org> | 2007-03-06 21:37:12 +0800 |
commit | cec647a409fd0beefc6025bfaead92cbdd5d7f9b (patch) | |
tree | 1de0f4b9c99304d1526b7bb8a5a6d4ac5afb1d26 /x11/kdelibs4 | |
parent | 4c0780c976d533b110e0f465ef303a26a039b83b (diff) | |
download | freebsd-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/Makefile | 2 | ||||
-rw-r--r-- | x11/kdelibs4/files/patch-khtml_ecma-kjs_html.cpp | 36 |
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()); |