| /* |
| * Copyright (C) 2007, 2008 Apple Inc. All rights reserved. |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Library General Public |
| * License as published by the Free Software Foundation; either |
| * version 2 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Library General Public License for more details. |
| * |
| * You should have received a copy of the GNU Library General Public License |
| * along with this library; see the file COPYING.LIB. If not, write to |
| * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| * Boston, MA 02110-1301, USA. |
| */ |
| |
| #include "config.h" |
| #include "JSDocument.h" |
| |
| #include "DOMWindow.h" |
| #include "Document.h" |
| #include "Frame.h" |
| #include "FrameLoader.h" |
| #include "HTMLDocument.h" |
| #include "JSDOMWindow.h" |
| #include "JSHTMLDocument.h" |
| #include "JSLocation.h" |
| #include "kjs_binding.h" |
| #include "kjs_proxy.h" |
| |
| #if ENABLE(SVG) |
| #include "JSSVGDocument.h" |
| #include "SVGDocument.h" |
| #endif |
| |
| namespace WebCore { |
| |
| using namespace KJS; |
| |
| void JSDocument::mark() |
| { |
| JSEventTargetNode::mark(); |
| ScriptInterpreter::markDOMNodesForDocument(static_cast<Document*>(impl())); |
| } |
| |
| JSValue* JSDocument::location(ExecState* exec) const |
| { |
| Frame* frame = static_cast<Document*>(impl())->frame(); |
| if (!frame) |
| return jsNull(); |
| |
| KJS::Window* win = KJS::Window::retrieveWindow(frame); |
| ASSERT(win); |
| return win->location(); |
| } |
| |
| void JSDocument::setLocation(ExecState* exec, JSValue* value) |
| { |
| Frame* frame = static_cast<Document*>(impl())->frame(); |
| if (!frame) |
| return; |
| |
| String str = value->toString(exec); |
| |
| // IE and Mozilla both resolve the URL relative to the source frame, |
| // not the target frame. |
| Frame* activeFrame = static_cast<JSDOMWindow*>(exec->dynamicGlobalObject())->impl()->frame(); |
| if (activeFrame) |
| str = activeFrame->document()->completeURL(str); |
| |
| bool userGesture = activeFrame->scriptProxy()->processingUserGesture(); |
| frame->loader()->scheduleLocationChange(str, activeFrame->loader()->outgoingReferrer(), false, userGesture); |
| } |
| |
| JSValue* toJS(ExecState* exec, Document* doc) |
| { |
| if (!doc) |
| return jsNull(); |
| |
| JSDocument* ret = static_cast<JSDocument*>(ScriptInterpreter::getDOMObject(doc)); |
| if (ret) |
| return ret; |
| |
| if (doc->isHTMLDocument()) |
| ret = new JSHTMLDocument(JSHTMLDocumentPrototype::self(exec), static_cast<HTMLDocument*>(doc)); |
| #if ENABLE(SVG) |
| else if (doc->isSVGDocument()) |
| ret = new JSSVGDocument(JSSVGDocumentPrototype::self(exec), static_cast<SVGDocument*>(doc)); |
| #endif |
| else |
| ret = new JSDocument(JSDocumentPrototype::self(exec), doc); |
| |
| // Make sure the document is kept around by the window object, and works right with the |
| // back/forward cache. |
| if (doc->frame()) |
| KJS::Window::retrieveWindow(doc->frame())->putDirect("document", ret, DontDelete|ReadOnly); |
| else { |
| size_t nodeCount = 0; |
| for (Node* n = doc; n; n = n->traverseNextNode()) |
| nodeCount++; |
| |
| Collector::reportExtraMemoryCost(nodeCount * sizeof(Node)); |
| } |
| |
| ScriptInterpreter::putDOMObject(doc, ret); |
| |
| return ret; |
| } |
| |
| } // namespace WebCore |