OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 1997 Martin Jones (mjones@kde.org) | 2 * Copyright (C) 1997 Martin Jones (mjones@kde.org) |
3 * (C) 1997 Torben Weis (weis@kde.org) | 3 * (C) 1997 Torben Weis (weis@kde.org) |
4 * (C) 1998 Waldo Bastian (bastian@kde.org) | 4 * (C) 1998 Waldo Bastian (bastian@kde.org) |
5 * (C) 1999 Lars Knoll (knoll@kde.org) | 5 * (C) 1999 Lars Knoll (knoll@kde.org) |
6 * (C) 1999 Antti Koivisto (koivisto@kde.org) | 6 * (C) 1999 Antti Koivisto (koivisto@kde.org) |
7 * Copyright (C) 2003, 2004, 2005, 2006, 2009 Apple Inc. All rights reserved. | 7 * Copyright (C) 2003, 2004, 2005, 2006, 2009 Apple Inc. All rights reserved. |
8 * Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies) | 8 * Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies) |
9 * | 9 * |
10 * This library is free software; you can redistribute it and/or | 10 * This library is free software; you can redistribute it and/or |
(...skipping 18 matching lines...) Expand all Loading... |
29 #include "core/HTMLNames.h" | 29 #include "core/HTMLNames.h" |
30 #include "core/html/HTMLTableColElement.h" | 30 #include "core/html/HTMLTableColElement.h" |
31 #include "core/layout/LayoutTable.h" | 31 #include "core/layout/LayoutTable.h" |
32 #include "core/layout/LayoutTableCell.h" | 32 #include "core/layout/LayoutTableCell.h" |
33 | 33 |
34 namespace blink { | 34 namespace blink { |
35 | 35 |
36 using namespace HTMLNames; | 36 using namespace HTMLNames; |
37 | 37 |
38 LayoutTableCol::LayoutTableCol(Element* element) | 38 LayoutTableCol::LayoutTableCol(Element* element) |
39 : RenderBox(element) | 39 : LayoutBox(element) |
40 , m_span(1) | 40 , m_span(1) |
41 { | 41 { |
42 // init LayoutObject attributes | 42 // init LayoutObject attributes |
43 setInline(true); // our object is not Inline | 43 setInline(true); // our object is not Inline |
44 updateFromElement(); | 44 updateFromElement(); |
45 } | 45 } |
46 | 46 |
47 void LayoutTableCol::styleDidChange(StyleDifference diff, const LayoutStyle* old
Style) | 47 void LayoutTableCol::styleDidChange(StyleDifference diff, const LayoutStyle* old
Style) |
48 { | 48 { |
49 RenderBox::styleDidChange(diff, oldStyle); | 49 LayoutBox::styleDidChange(diff, oldStyle); |
50 | 50 |
51 // If border was changed, notify table. | 51 // If border was changed, notify table. |
52 if (parent()) { | 52 if (parent()) { |
53 LayoutTable* table = this->table(); | 53 LayoutTable* table = this->table(); |
54 if (table && !table->selfNeedsLayout() && !table->normalChildNeedsLayout
() && oldStyle && oldStyle->border() != style()->border()) { | 54 if (table && !table->selfNeedsLayout() && !table->normalChildNeedsLayout
() && oldStyle && oldStyle->border() != style()->border()) { |
55 table->invalidateCollapsedBorders(); | 55 table->invalidateCollapsedBorders(); |
56 } else if (oldStyle && oldStyle->logicalWidth() != style()->logicalWidth
()) { | 56 } else if (oldStyle && oldStyle->logicalWidth() != style()->logicalWidth
()) { |
57 // FIXME : setPreferredLogicalWidthsDirty is done for all cells as o
f now. | 57 // FIXME : setPreferredLogicalWidthsDirty is done for all cells as o
f now. |
58 // Need to find a better way so that only the cells which are change
d by | 58 // Need to find a better way so that only the cells which are change
d by |
59 // the col width should have preferred logical widths recomputed. | 59 // the col width should have preferred logical widths recomputed. |
(...skipping 19 matching lines...) Expand all Loading... |
79 m_span = tc.span(); | 79 m_span = tc.span(); |
80 } else { | 80 } else { |
81 m_span = !(style() && style()->display() == TABLE_COLUMN_GROUP); | 81 m_span = !(style() && style()->display() == TABLE_COLUMN_GROUP); |
82 } | 82 } |
83 if (m_span != oldSpan && style() && parent()) | 83 if (m_span != oldSpan && style() && parent()) |
84 setNeedsLayoutAndPrefWidthsRecalcAndFullPaintInvalidation(); | 84 setNeedsLayoutAndPrefWidthsRecalcAndFullPaintInvalidation(); |
85 } | 85 } |
86 | 86 |
87 void LayoutTableCol::insertedIntoTree() | 87 void LayoutTableCol::insertedIntoTree() |
88 { | 88 { |
89 RenderBox::insertedIntoTree(); | 89 LayoutBox::insertedIntoTree(); |
90 table()->addColumn(this); | 90 table()->addColumn(this); |
91 } | 91 } |
92 | 92 |
93 void LayoutTableCol::willBeRemovedFromTree() | 93 void LayoutTableCol::willBeRemovedFromTree() |
94 { | 94 { |
95 RenderBox::willBeRemovedFromTree(); | 95 LayoutBox::willBeRemovedFromTree(); |
96 table()->removeColumn(this); | 96 table()->removeColumn(this); |
97 } | 97 } |
98 | 98 |
99 bool LayoutTableCol::isChildAllowed(LayoutObject* child, const LayoutStyle& styl
e) const | 99 bool LayoutTableCol::isChildAllowed(LayoutObject* child, const LayoutStyle& styl
e) const |
100 { | 100 { |
101 // We cannot use isTableColumn here as style() may return 0. | 101 // We cannot use isTableColumn here as style() may return 0. |
102 return child->isLayoutTableCol() && style.display() == TABLE_COLUMN; | 102 return child->isLayoutTableCol() && style.display() == TABLE_COLUMN; |
103 } | 103 } |
104 | 104 |
105 bool LayoutTableCol::canHaveChildren() const | 105 bool LayoutTableCol::canHaveChildren() const |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
189 return style()->borderStart(); | 189 return style()->borderStart(); |
190 } | 190 } |
191 | 191 |
192 const BorderValue& LayoutTableCol::borderAdjoiningCellAfter(const LayoutTableCel
l* cell) const | 192 const BorderValue& LayoutTableCol::borderAdjoiningCellAfter(const LayoutTableCel
l* cell) const |
193 { | 193 { |
194 ASSERT_UNUSED(cell, table()->colElement(cell->col() - 1) == this); | 194 ASSERT_UNUSED(cell, table()->colElement(cell->col() - 1) == this); |
195 return style()->borderEnd(); | 195 return style()->borderEnd(); |
196 } | 196 } |
197 | 197 |
198 } | 198 } |
OLD | NEW |