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

Side by Side Diff: Source/core/rendering/RenderBlock.h

Issue 459353002: Oilpan: Move more code of RenderObject destructors to destroy(). (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 6 years, 4 months 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
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) 2007 David Smith (catfish.man@gmail.com) 4 * (C) 2007 David Smith (catfish.man@gmail.com)
5 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 Apple Inc. All r ights reserved. 5 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 Apple Inc. All r ights reserved.
6 * 6 *
7 * This library is free software; you can redistribute it and/or 7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Library General Public 8 * modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either 9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version. 10 * version 2 of the License, or (at your option) any later version.
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
48 template <class Run> class BidiRunList; 48 template <class Run> class BidiRunList;
49 typedef WTF::ListHashSet<RenderBox*, 16> TrackedRendererListHashSet; 49 typedef WTF::ListHashSet<RenderBox*, 16> TrackedRendererListHashSet;
50 typedef WTF::HashMap<const RenderBlock*, OwnPtr<TrackedRendererListHashSet> > Tr ackedDescendantsMap; 50 typedef WTF::HashMap<const RenderBlock*, OwnPtr<TrackedRendererListHashSet> > Tr ackedDescendantsMap;
51 typedef WTF::HashMap<const RenderBox*, OwnPtr<HashSet<RenderBlock*> > > TrackedC ontainerMap; 51 typedef WTF::HashMap<const RenderBox*, OwnPtr<HashSet<RenderBlock*> > > TrackedC ontainerMap;
52 typedef Vector<WordMeasurement, 64> WordMeasurements; 52 typedef Vector<WordMeasurement, 64> WordMeasurements;
53 53
54 enum ContainingBlockState { NewContainingBlock, SameContainingBlock }; 54 enum ContainingBlockState { NewContainingBlock, SameContainingBlock };
55 55
56 class RenderBlock : public RenderBox { 56 class RenderBlock : public RenderBox {
57 public: 57 public:
58 virtual void destroy() OVERRIDE;
58 virtual void trace(Visitor*) OVERRIDE; 59 virtual void trace(Visitor*) OVERRIDE;
59 friend class LineLayoutState; 60 friend class LineLayoutState;
60 61
61 protected: 62 protected:
62 explicit RenderBlock(ContainerNode*); 63 explicit RenderBlock(ContainerNode*);
63 virtual ~RenderBlock(); 64 virtual ~RenderBlock();
64 65
65 public: 66 public:
66 RenderObject* firstChild() const { ASSERT(children() == virtualChildren()); return children()->firstChild(); } 67 RenderObject* firstChild() const { ASSERT(children() == virtualChildren()); return children()->firstChild(); }
67 RenderObject* lastChild() const { ASSERT(children() == virtualChildren()); r eturn children()->lastChild(); } 68 RenderObject* lastChild() const { ASSERT(children() == virtualChildren()); r eturn children()->lastChild(); }
(...skipping 368 matching lines...) Expand 10 before | Expand all | Expand 10 after
436 void splitFlow(RenderObject* beforeChild, RenderBlock* newBlockBox, 437 void splitFlow(RenderObject* beforeChild, RenderBlock* newBlockBox,
437 RenderObject* newChild, RenderBoxModelObject* oldCont); 438 RenderObject* newChild, RenderBoxModelObject* oldCont);
438 RenderBlock* clone() const; 439 RenderBlock* clone() const;
439 RenderBlock* continuationBefore(RenderObject* beforeChild); 440 RenderBlock* continuationBefore(RenderObject* beforeChild);
440 RenderBlockFlow* containingColumnsBlock(bool allowAnonymousColumnBlock = tru e); 441 RenderBlockFlow* containingColumnsBlock(bool allowAnonymousColumnBlock = tru e);
441 RenderBlockFlow* columnsBlockForSpanningElement(RenderObject* newChild); 442 RenderBlockFlow* columnsBlockForSpanningElement(RenderObject* newChild);
442 443
443 // End helper functions and structs used by layoutBlockChildren. 444 // End helper functions and structs used by layoutBlockChildren.
444 445
445 bool widthAvailableToChildrenHasChanged(); 446 bool widthAvailableToChildrenHasChanged();
447 void removeFromGlobalMaps();
446 448
447 protected: 449 protected:
448 // Returns the logicalOffset at the top of the next page. If the offset pass ed in is already at the top of the current page, 450 // Returns the logicalOffset at the top of the next page. If the offset pass ed in is already at the top of the current page,
449 // then nextPageLogicalTop with ExcludePageBoundary will still move to the t op of the next page. nextPageLogicalTop with 451 // then nextPageLogicalTop with ExcludePageBoundary will still move to the t op of the next page. nextPageLogicalTop with
450 // IncludePageBoundary set will not. 452 // IncludePageBoundary set will not.
451 // 453 //
452 // For a page height of 800px, the first rule will return 800 if the value p assed in is 0. The second rule will simply return 0. 454 // For a page height of 800px, the first rule will return 800 if the value p assed in is 0. The second rule will simply return 0.
453 enum PageBoundaryRule { ExcludePageBoundary, IncludePageBoundary }; 455 enum PageBoundaryRule { ExcludePageBoundary, IncludePageBoundary };
454 LayoutUnit nextPageLogicalTop(LayoutUnit logicalOffset, PageBoundaryRule = E xcludePageBoundary) const; 456 LayoutUnit nextPageLogicalTop(LayoutUnit logicalOffset, PageBoundaryRule = E xcludePageBoundary) const;
455 457
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
506 // FIXME: This is temporary as we move code that accesses block flow 508 // FIXME: This is temporary as we move code that accesses block flow
507 // member variables out of RenderBlock and into RenderBlockFlow. 509 // member variables out of RenderBlock and into RenderBlockFlow.
508 friend class RenderBlockFlow; 510 friend class RenderBlockFlow;
509 }; 511 };
510 512
511 DEFINE_RENDER_OBJECT_TYPE_CASTS(RenderBlock, isRenderBlock()); 513 DEFINE_RENDER_OBJECT_TYPE_CASTS(RenderBlock, isRenderBlock());
512 514
513 } // namespace blink 515 } // namespace blink
514 516
515 #endif // RenderBlock_h 517 #endif // RenderBlock_h
OLDNEW
« no previous file with comments | « no previous file | Source/core/rendering/RenderBlock.cpp » ('j') | Source/core/rendering/RenderBlock.cpp » ('J')

Powered by Google App Engine
This is Rietveld 408576698