/* * Copyright (C) 2011 Google Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Neither the name of Google Inc. nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef ShadowRoot_h #define ShadowRoot_h #include "ContainerNode.h" #include "Document.h" #include "DocumentFragment.h" #include "Element.h" #include "ExceptionCode.h" #include "TreeScope.h" namespace WebCore { class ElementShadow; class ShadowRoot FINAL : public DocumentFragment, public TreeScope { public: // FIXME: We will support multiple shadow subtrees, however current implementation does not work well // if a shadow root is dynamically created. So we prohibit multiple shadow subtrees // in several elements for a while. // See https://bugs.webkit.org/show_bug.cgi?id=77503 and related bugs. enum ShadowRootType { UserAgentShadowRoot = 0, AuthorShadowRoot }; static PassRefPtr create(Document* document, ShadowRootType type) { return adoptRef(new ShadowRoot(document, type)); } virtual ~ShadowRoot(); void recalcStyle(StyleChange); virtual bool applyAuthorStyles() const OVERRIDE { return m_applyAuthorStyles; } void setApplyAuthorStyles(bool); virtual bool resetStyleInheritance() const OVERRIDE { return m_resetStyleInheritance; } void setResetStyleInheritance(bool); Element* host() const { return toElement(parentOrShadowHostNode()); } ElementShadow* owner() const { return host() ? host()->shadow() : 0; } String innerHTML() const; void setInnerHTML(const String&, ExceptionCode&); Element* activeElement() const; virtual void attach(const AttachContext& = AttachContext()) OVERRIDE; virtual void registerScopedHTMLStyleChild() OVERRIDE; virtual void unregisterScopedHTMLStyleChild() OVERRIDE; ShadowRootType type() const { return static_cast(m_type); } PassRefPtr cloneNode(bool, ExceptionCode&); private: ShadowRoot(Document*, ShadowRootType); virtual void dispose() OVERRIDE; virtual bool childTypeAllowed(NodeType) const OVERRIDE; virtual void childrenChanged(bool changedByParser, Node* beforeChange, Node* afterChange, int childCountDelta) OVERRIDE; // ShadowRoots should never be cloned. virtual PassRefPtr cloneNode(bool) OVERRIDE { return 0; } // FIXME: This shouldn't happen. https://bugs.webkit.org/show_bug.cgi?id=88834 bool isOrphan() const { return !host(); } unsigned m_numberOfStyles : 28; unsigned m_applyAuthorStyles : 1; unsigned m_resetStyleInheritance : 1; unsigned m_type : 1; }; inline Element* ShadowRoot::activeElement() const { return treeScope()->focusedElement(); } inline const ShadowRoot* toShadowRoot(const Node* node) { ASSERT_WITH_SECURITY_IMPLICATION(!node || node->isShadowRoot()); return static_cast(node); } inline ShadowRoot* toShadowRoot(Node* node) { return const_cast(toShadowRoot(static_cast(node))); } } // namespace #endif