Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2000 Lars Knoll (knoll@kde.org) | 2 * Copyright (C) 2000 Lars Knoll (knoll@kde.org) |
| 3 * Copyright (C) 2003, 2004, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All r ight reserved. | 3 * Copyright (C) 2003, 2004, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All r ight reserved. |
| 4 * Copyright (C) 2010 Google Inc. All rights reserved. | 4 * Copyright (C) 2010 Google Inc. All rights reserved. |
| 5 * | 5 * |
| 6 * This library is free software; you can redistribute it and/or | 6 * This library is free software; you can redistribute it and/or |
| 7 * modify it under the terms of the GNU Library General Public | 7 * modify it under the terms of the GNU Library General Public |
| 8 * License as published by the Free Software Foundation; either | 8 * License as published by the Free Software Foundation; either |
| 9 * version 2 of the License, or (at your option) any later version. | 9 * version 2 of the License, or (at your option) any later version. |
| 10 * | 10 * |
| (...skipping 2061 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2072 return logicalLeft; | 2072 return logicalLeft; |
| 2073 } | 2073 } |
| 2074 | 2074 |
| 2075 void LayoutBlockFlow::invalidateDisplayItemClientsOfFirstLine() | 2075 void LayoutBlockFlow::invalidateDisplayItemClientsOfFirstLine() |
| 2076 { | 2076 { |
| 2077 ASSERT(childrenInline()); | 2077 ASSERT(childrenInline()); |
| 2078 if (RootInlineBox* firstRootBox = this->firstRootBox()) | 2078 if (RootInlineBox* firstRootBox = this->firstRootBox()) |
| 2079 firstRootBox->invalidateDisplayItemClientsRecursively(); | 2079 firstRootBox->invalidateDisplayItemClientsRecursively(); |
| 2080 } | 2080 } |
| 2081 | 2081 |
| 2082 PaintInvalidationReason LayoutBlockFlow::invalidatePaintIfNeeded(PaintInvalidati onState& paintInvalidationState, const LayoutBoxModelObject& paintInvalidationCo ntainer) | |
|
Xianzhu
2015/12/18 17:24:54
This will miss the LayoutButton case, but I think
| |
| 2083 { | |
| 2084 PaintInvalidationReason reason = LayoutBlock::invalidatePaintIfNeeded(paintI nvalidationState, paintInvalidationContainer); | |
| 2085 if (reason == PaintInvalidationNone) | |
| 2086 return reason; | |
| 2087 RootInlineBox* line = firstRootBox(); | |
| 2088 if (!line || !line->isFirstLineStyle()) | |
| 2089 return reason; | |
| 2090 // It's the RootInlineBox that paints the ::first-line background. | |
| 2091 invalidateDisplayItemClient(*line); | |
|
Xianzhu
2015/12/18 07:01:20
Will this always invalidate the first line, even i
mstensho (USE GERRIT)
2015/12/18 10:33:04
Yeah, looks like it. That wasn't my intention.
mstensho (USE GERRIT)
2015/12/18 13:11:11
Fixed it. Not sure if it's worth it, though. Could
Xianzhu
2015/12/18 17:24:54
Hmm enclosingFirstLineStyleBlock() seems not cheap
mstensho (USE GERRIT)
2015/12/21 10:54:10
Done. Added a comment too.
| |
| 2092 return reason; | |
| 2082 } | 2093 } |
| 2094 | |
| 2095 } | |
| OLD | NEW |