Chromium Code Reviews| 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 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 50 RenderBox::trace(visitor); | 50 RenderBox::trace(visitor); |
| 51 } | 51 } |
| 52 | 52 |
| 53 void RenderTableCol::styleDidChange(StyleDifference diff, const RenderStyle* old Style) | 53 void RenderTableCol::styleDidChange(StyleDifference diff, const RenderStyle* old Style) |
| 54 { | 54 { |
| 55 RenderBox::styleDidChange(diff, oldStyle); | 55 RenderBox::styleDidChange(diff, oldStyle); |
| 56 | 56 |
| 57 // If border was changed, notify table. | 57 // If border was changed, notify table. |
| 58 if (parent()) { | 58 if (parent()) { |
| 59 RenderTable* table = this->table(); | 59 RenderTable* table = this->table(); |
| 60 if (table && !table->selfNeedsLayout() && !table->normalChildNeedsLayout () && oldStyle && oldStyle->border() != style()->border()) | 60 if (table && !table->selfNeedsLayout() && !table->normalChildNeedsLayout () && oldStyle && oldStyle->border() != style()->border()) { |
| 61 table->invalidateCollapsedBorders(); | 61 table->invalidateCollapsedBorders(); |
| 62 } else if (oldStyle && oldStyle->logicalWidth() != style()->logicalWidth ()) { | |
| 63 // FIXME : setPreferredLogicalWidthsDirty is done for all cells as o f now. | |
| 64 // Need to find a better way so that only the cells which are change d by | |
| 65 // the col width should have preferred logical widths recomputed. | |
|
mstensho (USE GERRIT)
2015/01/09 21:21:35
-"should".
| |
| 66 table->recalcSectionsIfNeeded(); | |
|
mstensho (USE GERRIT)
2015/01/09 21:21:35
See https://codereview.chromium.org/208263013/#msg
| |
| 67 unsigned nEffCols = table->numEffCols(); | |
| 68 for (RenderTableSection* section = table->topSection(); section; sec tion = table->sectionBelow(section)) { | |
| 69 for (unsigned j = 0; j < nEffCols; j++) { | |
| 70 for (unsigned i = 0; i < section->numRows(); i++) { | |
| 71 RenderTableCell* cell = section->primaryCellAt(i, j); | |
| 72 if (!cell) | |
| 73 continue; | |
| 74 cell->setPreferredLogicalWidthsDirty(); | |
| 75 } | |
| 76 } | |
| 77 } | |
| 78 } | |
| 62 } | 79 } |
| 63 } | 80 } |
| 64 | 81 |
| 65 void RenderTableCol::updateFromElement() | 82 void RenderTableCol::updateFromElement() |
| 66 { | 83 { |
| 67 unsigned oldSpan = m_span; | 84 unsigned oldSpan = m_span; |
| 68 Node* n = node(); | 85 Node* n = node(); |
| 69 if (isHTMLTableColElement(n)) { | 86 if (isHTMLTableColElement(n)) { |
| 70 HTMLTableColElement& tc = toHTMLTableColElement(*n); | 87 HTMLTableColElement& tc = toHTMLTableColElement(*n); |
| 71 m_span = tc.span(); | 88 m_span = tc.span(); |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 180 return style()->borderStart(); | 197 return style()->borderStart(); |
| 181 } | 198 } |
| 182 | 199 |
| 183 const BorderValue& RenderTableCol::borderAdjoiningCellAfter(const RenderTableCel l* cell) const | 200 const BorderValue& RenderTableCol::borderAdjoiningCellAfter(const RenderTableCel l* cell) const |
| 184 { | 201 { |
| 185 ASSERT_UNUSED(cell, table()->colElement(cell->col() - 1) == this); | 202 ASSERT_UNUSED(cell, table()->colElement(cell->col() - 1) == this); |
| 186 return style()->borderEnd(); | 203 return style()->borderEnd(); |
| 187 } | 204 } |
| 188 | 205 |
| 189 } | 206 } |
| OLD | NEW |