Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(461)

Side by Side Diff: Source/core/dom/RenderTreeBuilder.h

Issue 699213003: RenderTreeBuilder => RenderTreeBuilderForElement and RenderTreeBuilderForText (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « Source/core/dom/Element.cpp ('k') | Source/core/dom/RenderTreeBuilder.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org)
3 * (C) 1999 Antti Koivisto (koivisto@kde.org) 3 * (C) 1999 Antti Koivisto (koivisto@kde.org)
4 * (C) 2001 Dirk Mueller (mueller@kde.org) 4 * (C) 2001 Dirk Mueller (mueller@kde.org)
5 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All r ights reserved. 5 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All r ights reserved.
6 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. (http://www.t orchmobile.com/) 6 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. (http://www.t orchmobile.com/)
7 * Copyright (C) 2011 Google Inc. All rights reserved. 7 * Copyright (C) 2011 Google Inc. All rights reserved.
8 * 8 *
9 * This library is free software; you can redistribute it and/or 9 * This library is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Library General Public 10 * modify it under the terms of the GNU Library General Public
(...skipping 11 matching lines...) Expand all
22 * Boston, MA 02110-1301, USA. 22 * Boston, MA 02110-1301, USA.
23 * 23 *
24 */ 24 */
25 25
26 #ifndef RenderTreeBuilder_h 26 #ifndef RenderTreeBuilder_h
27 #define RenderTreeBuilder_h 27 #define RenderTreeBuilder_h
28 28
29 #include "core/dom/Document.h" 29 #include "core/dom/Document.h"
30 #include "core/dom/Node.h" 30 #include "core/dom/Node.h"
31 #include "core/dom/NodeRenderingTraversal.h" 31 #include "core/dom/NodeRenderingTraversal.h"
32 #include "core/dom/Text.h"
32 #include "wtf/RefPtr.h" 33 #include "wtf/RefPtr.h"
33 34
34 namespace blink { 35 namespace blink {
35 36
36 class ContainerNode; 37 class ContainerNode;
37 class RenderObject; 38 class RenderObject;
38 class RenderStyle; 39 class RenderStyle;
39 40
40 class RenderTreeBuilder { 41 class RenderTreeBuilder {
41 STACK_ALLOCATED(); 42 STACK_ALLOCATED();
42 public: 43 public:
43 RenderTreeBuilder(Node* node, RenderStyle* style) 44 RenderTreeBuilder(Node* node)
44 : m_node(node) 45 : m_node(node)
45 , m_renderingParent(nullptr) 46 , m_renderingParent(NodeRenderingTraversal::parent(node))
46 , m_style(style)
47 { 47 {
48 ASSERT(!node->renderer());
esprehn 2014/11/05 23:20:26 This assert is still valid, we shouldn't create on
49 ASSERT(node->needsAttach()); 48 ASSERT(node->needsAttach());
50 ASSERT(node->document().inStyleRecalc()); 49 ASSERT(node->document().inStyleRecalc());
51 50
52 // FIXME: We should be able to ASSERT(node->inActiveDocument()) but chil drenChanged is called 51 // FIXME: We should be able to ASSERT(node->inActiveDocument()) but chil drenChanged is called
53 // before ChildNodeInsertionNotifier in ContainerNode's methods and some implementations 52 // before ChildNodeInsertionNotifier in ContainerNode's methods and some implementations
54 // will trigger a layout inside childrenChanged. 53 // will trigger a layout inside childrenChanged.
55 // Mainly HTMLTextAreaElement::childrenChanged calls HTMLTextFormControl Element::setSelectionRange 54 // Mainly HTMLTextAreaElement::childrenChanged calls HTMLTextFormControl Element::setSelectionRange
56 // which does an updateLayoutIgnorePendingStylesheets. 55 // which does an updateLayoutIgnorePendingStylesheets.
57
58 m_renderingParent = NodeRenderingTraversal::parent(node, &m_parentDetail s);
59 } 56 }
60 57
61 void createRendererForTextIfNeeded(); 58 void createRendererIfNeeded();
62 void createRendererForElementIfNeeded(); 59 virtual void createRenderer() = 0;
60 virtual bool rendererIsNeeded() const;
esprehn 2014/11/05 23:20:25 Does the compiler devirtualize this?
63 61
64 private: 62 protected:
65 RenderObject* parentRenderer() const; 63 virtual RenderObject* parentRenderer() const;
66 RenderObject* nextRenderer() const; 64 RenderObject* nextRenderer() const;
67 bool shouldCreateRenderer() const;
68 RenderStyle& style() const;
69 65
70 RawPtrWillBeMember<Node> m_node; 66 RawPtrWillBeMember<Node> m_node;
71 RawPtrWillBeMember<ContainerNode> m_renderingParent; 67 RawPtrWillBeMember<ContainerNode> m_renderingParent;
72 NodeRenderingTraversal::ParentDetails m_parentDetails; 68 };
73 mutable RefPtr<RenderStyle> m_style; 69
70 class RenderTreeBuilderForElement : public RenderTreeBuilder {
71 public:
72 RenderTreeBuilderForElement(Element* element, PassRefPtr<RenderStyle> style)
73 : RenderTreeBuilder(element)
74 , m_style(style) { }
75
76 virtual void createRenderer() override final;
77 virtual bool rendererIsNeeded() const override final;
78
79 private:
80 virtual RenderObject* parentRenderer() const override final;
81
82 RefPtr<RenderStyle> m_style;
83 };
84
85 class RenderTreeBuilderForText : public RenderTreeBuilder {
86 public:
87 RenderTreeBuilderForText(Text* text)
88 : RenderTreeBuilder(text) { }
89
90 virtual void createRenderer() override final;
91 virtual bool rendererIsNeeded() const override final;
74 }; 92 };
75 93
76 } // namespace blink 94 } // namespace blink
77 95
78 #endif 96 #endif
OLDNEW
« no previous file with comments | « Source/core/dom/Element.cpp ('k') | Source/core/dom/RenderTreeBuilder.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698