2 * Copyright (C) 2012 Google Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Neither the name of Google Inc. nor the names of its
11 * contributors may be used to endorse or promote products derived from
12 * this software without specific prior written permission.
14 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
15 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
16 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
17 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
18 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
19 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
20 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 #ifndef LayoutTreeBuilderTraversal_h
28 #define LayoutTreeBuilderTraversal_h
30 #include "core/CoreExport.h"
31 #include "core/dom/Element.h"
38 namespace LayoutTreeBuilderTraversal
{
44 : m_insertionPoint(nullptr)
47 const InsertionPoint
* insertionPoint() const { return m_insertionPoint
; }
49 void didTraverseInsertionPoint(const InsertionPoint
*);
51 bool operator==(const ParentDetails
& other
)
53 return m_insertionPoint
== other
.m_insertionPoint
;
57 RawPtrWillBeMember
<const InsertionPoint
> m_insertionPoint
;
60 CORE_EXPORT ContainerNode
* parent(const Node
&, ParentDetails
* = 0);
61 CORE_EXPORT Node
* firstChild(const Node
&);
62 CORE_EXPORT Node
* nextSibling(const Node
&);
63 Node
* previousSibling(const Node
&);
64 Node
* previous(const Node
&, const Node
* stayWithin
);
65 Node
* next(const Node
&, const Node
* stayWithin
);
66 Node
* nextSkippingChildren(const Node
&, const Node
* stayWithin
);
67 LayoutObject
* nextSiblingLayoutObject(const Node
&);
68 LayoutObject
* previousSiblingLayoutObject(const Node
&);
69 LayoutObject
* nextInTopLayer(const Element
&);
71 inline Element
* parentElement(const Node
& node
)
73 ContainerNode
* found
= parent(node
);
74 return found
&& found
->isElementNode() ? toElement(found
) : 0;