This source file includes following definitions.
- url
- securityOrigin
- encoding
- contentLanguage
- referrer
- openSearchDescriptionURL
- frame
- isHTMLDocument
- isXHTMLDocument
- isPluginDocument
- baseURL
- firstPartyForCookies
- documentElement
- body
- head
- title
- all
- images
- forms
- completeURL
- getElementById
- focusedElement
- doctype
- insertStyleSheet
- watchCSSSelectors
- cancelFullScreen
- fullScreenElement
- createEvent
- referrerPolicy
- createElement
- accessibilityObject
- accessibilityObjectFromID
- draggableRegions
- registerEmbedderCustomElement
#include "config.h"
#include "WebDocument.h"
#include "WebAXObject.h"
#include "WebDOMEvent.h"
#include "WebDocumentType.h"
#include "WebElement.h"
#include "WebElementCollection.h"
#include "WebFormElement.h"
#include "WebFrameImpl.h"
#include "WebNodeList.h"
#include "bindings/v8/Dictionary.h"
#include "bindings/v8/ExceptionState.h"
#include "bindings/v8/NewScriptState.h"
#include "bindings/v8/ScriptValue.h"
#include "core/accessibility/AXObjectCache.h"
#include "core/css/CSSParserMode.h"
#include "core/css/StyleSheetContents.h"
#include "core/dom/CSSSelectorWatch.h"
#include "core/dom/Document.h"
#include "core/dom/DocumentType.h"
#include "core/dom/Element.h"
#include "core/dom/FullscreenElementStack.h"
#include "core/dom/NodeList.h"
#include "core/dom/StyleEngine.h"
#include "core/html/HTMLAllCollection.h"
#include "core/html/HTMLBodyElement.h"
#include "core/html/HTMLCollection.h"
#include "core/html/HTMLElement.h"
#include "core/html/HTMLFormElement.h"
#include "core/html/HTMLHeadElement.h"
#include "core/loader/DocumentLoader.h"
#include "core/rendering/RenderObject.h"
#include "platform/weborigin/SecurityOrigin.h"
#include "public/platform/WebURL.h"
#include "wtf/PassRefPtr.h"
#include <v8.h>
using namespace WebCore;
namespace blink {
WebURL WebDocument::url() const
{
return constUnwrap<Document>()->url();
}
WebSecurityOrigin WebDocument::securityOrigin() const
{
if (!constUnwrap<Document>())
return WebSecurityOrigin();
return WebSecurityOrigin(constUnwrap<Document>()->securityOrigin());
}
WebString WebDocument::encoding() const
{
return constUnwrap<Document>()->encodingName();
}
WebString WebDocument::contentLanguage() const
{
return constUnwrap<Document>()->contentLanguage();
}
WebString WebDocument::referrer() const
{
return constUnwrap<Document>()->referrer();
}
WebURL WebDocument::openSearchDescriptionURL() const
{
return const_cast<Document*>(constUnwrap<Document>())->openSearchDescriptionURL();
}
WebLocalFrame* WebDocument::frame() const
{
return WebFrameImpl::fromFrame(constUnwrap<Document>()->frame());
}
bool WebDocument::isHTMLDocument() const
{
return constUnwrap<Document>()->isHTMLDocument();
}
bool WebDocument::isXHTMLDocument() const
{
return constUnwrap<Document>()->isXHTMLDocument();
}
bool WebDocument::isPluginDocument() const
{
return constUnwrap<Document>()->isPluginDocument();
}
WebURL WebDocument::baseURL() const
{
return constUnwrap<Document>()->baseURL();
}
WebURL WebDocument::firstPartyForCookies() const
{
return constUnwrap<Document>()->firstPartyForCookies();
}
WebElement WebDocument::documentElement() const
{
return WebElement(constUnwrap<Document>()->documentElement());
}
WebElement WebDocument::body() const
{
return WebElement(constUnwrap<Document>()->body());
}
WebElement WebDocument::head()
{
return WebElement(unwrap<Document>()->head());
}
WebString WebDocument::title() const
{
return WebString(constUnwrap<Document>()->title());
}
WebElementCollection WebDocument::all()
{
return WebElementCollection(unwrap<Document>()->all());
}
void WebDocument::images(WebVector<WebElement>& results)
{
RefPtr<HTMLCollection> images = unwrap<Document>()->images();
size_t sourceLength = images->length();
Vector<WebElement> temp;
temp.reserveCapacity(sourceLength);
for (size_t i = 0; i < sourceLength; ++i) {
Element* element = images->item(i);
if (element && element->isHTMLElement())
temp.append(WebElement(element));
}
results.assign(temp);
}
void WebDocument::forms(WebVector<WebFormElement>& results) const
{
RefPtr<HTMLCollection> forms = const_cast<Document*>(constUnwrap<Document>())->forms();
size_t sourceLength = forms->length();
Vector<WebFormElement> temp;
temp.reserveCapacity(sourceLength);
for (size_t i = 0; i < sourceLength; ++i) {
Element* element = forms->item(i);
if (element && element->isHTMLElement())
temp.append(WebFormElement(toHTMLFormElement(element)));
}
results.assign(temp);
}
WebURL WebDocument::completeURL(const WebString& partialURL) const
{
return constUnwrap<Document>()->completeURL(partialURL);
}
WebElement WebDocument::getElementById(const WebString& id) const
{
return WebElement(constUnwrap<Document>()->getElementById(id));
}
WebElement WebDocument::focusedElement() const
{
return WebElement(constUnwrap<Document>()->focusedElement());
}
WebDocumentType WebDocument::doctype() const
{
return WebDocumentType(constUnwrap<Document>()->doctype());
}
void WebDocument::insertStyleSheet(const WebString& sourceCode)
{
RefPtr<Document> document = unwrap<Document>();
ASSERT(document);
RefPtrWillBeRawPtr<StyleSheetContents> parsedSheet = StyleSheetContents::create(CSSParserContext(*document.get(), 0));
parsedSheet->parseString(sourceCode);
document->styleEngine()->addAuthorSheet(parsedSheet);
}
void WebDocument::watchCSSSelectors(const WebVector<WebString>& webSelectors)
{
RefPtr<Document> document = unwrap<Document>();
Vector<String> selectors;
selectors.append(webSelectors.data(), webSelectors.size());
CSSSelectorWatch::from(*document).watchCSSSelectors(selectors);
}
void WebDocument::cancelFullScreen()
{
if (FullscreenElementStack* fullscreen = FullscreenElementStack::fromIfExists(*unwrap<Document>()))
fullscreen->webkitCancelFullScreen();
}
WebElement WebDocument::fullScreenElement() const
{
Element* fullScreenElement = 0;
if (FullscreenElementStack* fullscreen = FullscreenElementStack::fromIfExists(*const_cast<WebDocument*>(this)->unwrap<Document>()))
fullScreenElement = fullscreen->webkitCurrentFullScreenElement();
return WebElement(fullScreenElement);
}
WebDOMEvent WebDocument::createEvent(const WebString& eventType)
{
TrackExceptionState exceptionState;
WebDOMEvent event(unwrap<Document>()->createEvent(eventType, exceptionState));
if (exceptionState.hadException())
return WebDOMEvent();
return event;
}
WebReferrerPolicy WebDocument::referrerPolicy() const
{
return static_cast<WebReferrerPolicy>(constUnwrap<Document>()->referrerPolicy());
}
WebElement WebDocument::createElement(const WebString& tagName)
{
TrackExceptionState exceptionState;
WebElement element(unwrap<Document>()->createElement(tagName, exceptionState));
if (exceptionState.hadException())
return WebElement();
return element;
}
WebAXObject WebDocument::accessibilityObject() const
{
const Document* document = constUnwrap<Document>();
return WebAXObject(document->axObjectCache()->getOrCreate(document->renderer()));
}
WebAXObject WebDocument::accessibilityObjectFromID(int axID) const
{
const Document* document = constUnwrap<Document>();
return WebAXObject(document->axObjectCache()->objectFromAXID(axID));
}
WebVector<WebDraggableRegion> WebDocument::draggableRegions() const
{
WebVector<WebDraggableRegion> draggableRegions;
const Document* document = constUnwrap<Document>();
if (document->hasAnnotatedRegions()) {
const Vector<AnnotatedRegionValue>& regions = document->annotatedRegions();
draggableRegions = WebVector<WebDraggableRegion>(regions.size());
for (size_t i = 0; i < regions.size(); i++) {
const AnnotatedRegionValue& value = regions[i];
draggableRegions[i].draggable = value.draggable;
draggableRegions[i].bounds = WebCore::IntRect(value.bounds);
}
}
return draggableRegions;
}
v8::Handle<v8::Value> WebDocument::registerEmbedderCustomElement(const WebString& name, v8::Handle<v8::Value> options, WebExceptionCode& ec)
{
v8::Isolate* isolate = v8::Isolate::GetCurrent();
Document* document = unwrap<Document>();
Dictionary dictionary(options, isolate);
TrackExceptionState exceptionState;
ScriptValue constructor = document->registerElement(NewScriptState::current(isolate), name, dictionary, exceptionState, CustomElement::EmbedderNames);
ec = exceptionState.code();
if (exceptionState.hadException())
return v8::Handle<v8::Value>();
return constructor.v8Value();
}
WebDocument::WebDocument(const PassRefPtr<Document>& elem)
: WebNode(elem)
{
}
WebDocument& WebDocument::operator=(const PassRefPtr<Document>& elem)
{
m_private = elem;
return *this;
}
WebDocument::operator PassRefPtr<Document>() const
{
return toDocument(m_private.get());
}
}