| OLD | NEW |
| 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 323 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 334 virtual bool shouldIgnoreOverflowPropertyForInlineBlockBaseline() const { re
turn false; } | 334 virtual bool shouldIgnoreOverflowPropertyForInlineBlockBaseline() const { re
turn false; } |
| 335 | 335 |
| 336 void updateHitTestResult(HitTestResult&, const LayoutPoint&) override; | 336 void updateHitTestResult(HitTestResult&, const LayoutPoint&) override; |
| 337 | 337 |
| 338 // Delay update scrollbar until finishDelayUpdateScrollInfo() will be | 338 // Delay update scrollbar until finishDelayUpdateScrollInfo() will be |
| 339 // called. This function is used when a flexbox is laying out its | 339 // called. This function is used when a flexbox is laying out its |
| 340 // descendant. If multiple calls are made to startDelayUpdateScrollInfo(), | 340 // descendant. If multiple calls are made to startDelayUpdateScrollInfo(), |
| 341 // finishDelayUpdateScrollInfo() will do nothing until finishDelayUpdateScro
llInfo() | 341 // finishDelayUpdateScrollInfo() will do nothing until finishDelayUpdateScro
llInfo() |
| 342 // is called the same number of times. | 342 // is called the same number of times. |
| 343 // finishDelayUpdateScrollInfo returns true when it marked something for lay
out. | 343 // finishDelayUpdateScrollInfo returns true when it marked something for lay
out. |
| 344 // It will also return a map of saved scroll positions that the caller shoul
d restore |
| 345 // on the given scrollable areas after performing the layout. |
| 346 // This can be necessary because Flexbox's multi-pass layout can lose the sc
roll position. |
| 347 // TODO(cbiesinger): This is a temporary hack. The right solution is to dela
y the scroll |
| 348 // clamping that currently happens in PaintLayerScrollableArea::updateAfterL
ayout to only |
| 349 // happen after all layout is done, i.e. during updateLayerPositionsAfterLay
out. However, |
| 350 // that currently fails a layout test. To fix this bug in time for M50, we u
se this temporary |
| 351 // hack. The real fix is tracked in crbug.com/600036 |
| 352 typedef WTF::HashMap<PaintLayerScrollableArea*, DoublePoint> ScrollPositionM
ap; |
| 344 static void startDelayUpdateScrollInfo(); | 353 static void startDelayUpdateScrollInfo(); |
| 345 static bool finishDelayUpdateScrollInfo(SubtreeLayoutScope*); | 354 static bool finishDelayUpdateScrollInfo(SubtreeLayoutScope*, ScrollPositionM
ap*); |
| 346 | 355 |
| 347 void updateScrollInfoAfterLayout(); | 356 void updateScrollInfoAfterLayout(); |
| 348 | 357 |
| 349 void styleWillChange(StyleDifference, const ComputedStyle& newStyle) overrid
e; | 358 void styleWillChange(StyleDifference, const ComputedStyle& newStyle) overrid
e; |
| 350 void styleDidChange(StyleDifference, const ComputedStyle* oldStyle) override
; | 359 void styleDidChange(StyleDifference, const ComputedStyle* oldStyle) override
; |
| 351 void updateFromStyle() override; | 360 void updateFromStyle() override; |
| 352 | 361 |
| 353 // Returns true if non-visible overflow should be respected. Otherwise hasOv
erflowClip() will be | 362 // Returns true if non-visible overflow should be respected. Otherwise hasOv
erflowClip() will be |
| 354 // false and we won't create scrollable area for this object even if overflo
w is non-visible. | 363 // false and we won't create scrollable area for this object even if overflo
w is non-visible. |
| 355 virtual bool allowsOverflowClip() const; | 364 virtual bool allowsOverflowClip() const; |
| (...skipping 154 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 510 // FIXME: This is temporary as we move code that accesses block flow | 519 // FIXME: This is temporary as we move code that accesses block flow |
| 511 // member variables out of LayoutBlock and into LayoutBlockFlow. | 520 // member variables out of LayoutBlock and into LayoutBlockFlow. |
| 512 friend class LayoutBlockFlow; | 521 friend class LayoutBlockFlow; |
| 513 }; | 522 }; |
| 514 | 523 |
| 515 DEFINE_LAYOUT_OBJECT_TYPE_CASTS(LayoutBlock, isLayoutBlock()); | 524 DEFINE_LAYOUT_OBJECT_TYPE_CASTS(LayoutBlock, isLayoutBlock()); |
| 516 | 525 |
| 517 } // namespace blink | 526 } // namespace blink |
| 518 | 527 |
| 519 #endif // LayoutBlock_h | 528 #endif // LayoutBlock_h |
| OLD | NEW |