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

Side by Side Diff: third_party/WebKit/Source/core/layout/LayoutInline.cpp

Issue 1473363003: Invalidate first line display item clients when first line style changes (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Handle inherited firstline style Created 5 years 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
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 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights reserved. 4 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009 Apple 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 1406 matching lines...) Expand 10 before | Expand all | Expand 10 after
1417 void LayoutInline::invalidateDisplayItemClients(const LayoutBoxModelObject& pain tInvalidationContainer, PaintInvalidationReason invalidationReason, const Layout Rect* paintInvalidationRect) const 1417 void LayoutInline::invalidateDisplayItemClients(const LayoutBoxModelObject& pain tInvalidationContainer, PaintInvalidationReason invalidationReason, const Layout Rect* paintInvalidationRect) const
1418 { 1418 {
1419 LayoutBoxModelObject::invalidateDisplayItemClients(paintInvalidationContaine r, invalidationReason, paintInvalidationRect); 1419 LayoutBoxModelObject::invalidateDisplayItemClients(paintInvalidationContaine r, invalidationReason, paintInvalidationRect);
1420 1420
1421 // Use the paintInvalidationRect of LayoutInline for inline boxes, which sav es the cost to calculate paint invalidation rect 1421 // Use the paintInvalidationRect of LayoutInline for inline boxes, which sav es the cost to calculate paint invalidation rect
1422 // for every inline box. This won't cause more rasterization invalidations b ecause the whole LayoutInline is being invalidated. 1422 // for every inline box. This won't cause more rasterization invalidations b ecause the whole LayoutInline is being invalidated.
1423 for (InlineFlowBox* box = firstLineBox(); box; box = box->nextLineBox()) 1423 for (InlineFlowBox* box = firstLineBox(); box; box = box->nextLineBox())
1424 paintInvalidationContainer.invalidateDisplayItemClientOnBacking(*box, in validationReason, paintInvalidationRect); 1424 paintInvalidationContainer.invalidateDisplayItemClientOnBacking(*box, in validationReason, paintInvalidationRect);
1425 } 1425 }
1426 1426
1427 void LayoutInline::invalidateDisplayItemClientsOfFirstLine()
1428 {
1429 if (alwaysCreateLineBoxes()) {
1430 for (InlineFlowBox* box = firstLineBox(); box; box = box->nextLineBox()) {
1431 if (!box->isFirstLineStyle())
1432 break;
1433 box->invalidateDisplayItemClientsOfFirstLine();
1434 }
1435 return;
1436 }
1437
1438 for (LayoutObject* child = firstChild(); child; child = child->nextSibling() ) {
mstensho (USE GERRIT) 2015/12/01 12:29:49 Looks like there's nothing that stops at the end o
Xianzhu 2015/12/01 20:06:25 I think invalidating the first line of containing
1439 child->setShouldDoFullPaintInvalidation();
chrishtr 2015/12/01 01:43:11 Why this line?
1440 if (child->isLayoutInline())
1441 toLayoutInline(child)->invalidateDisplayItemClientsOfFirstLine();
1442 else if (child->isText())
1443 toLayoutText(child)->invalidateDisplayItemClientsOfFirstLine();
1444 }
1445 }
1446
1427 } // namespace blink 1447 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698